Commit 6d2d2ae4 authored by Anthony Martin's avatar Anthony Martin

cmd/go: fix build -n for cgo enabled packages

R=golang-dev, minux.ma, rsc
CC=golang-dev
https://golang.org/cl/7095067
parent e7ef3b6d
...@@ -1534,10 +1534,28 @@ func gccgoCleanPkgpath(p *Package) string { ...@@ -1534,10 +1534,28 @@ func gccgoCleanPkgpath(p *Package) string {
// libgcc returns the filename for libgcc, as determined by invoking gcc with // libgcc returns the filename for libgcc, as determined by invoking gcc with
// the -print-libgcc-file-name option. // the -print-libgcc-file-name option.
func (b *builder) libgcc(p *Package) (string, error) { func (b *builder) libgcc(p *Package) (string, error) {
var buf bytes.Buffer
prev := b.print
if buildN {
// In -n mode we temporarily swap out the builder's
// print function to capture the command-line. This
// let's us assign it to $LIBGCC and produce a valid
// buildscript for cgo packages.
b.print = func(a ...interface{}) (n int, err error) {
return fmt.Fprint(&buf, a...)
}
}
f, err := b.runOut(p.Dir, p.ImportPath, b.gccCmd(p.Dir), "-print-libgcc-file-name") f, err := b.runOut(p.Dir, p.ImportPath, b.gccCmd(p.Dir), "-print-libgcc-file-name")
if err != nil { if err != nil {
return "", fmt.Errorf("gcc -print-libgcc-file-name: %v (%s)", err, f) return "", fmt.Errorf("gcc -print-libgcc-file-name: %v (%s)", err, f)
} }
if buildN {
s := fmt.Sprintf("LIBGCC=$(%s)\n", buf.Next(buf.Len()-1))
b.print = prev
b.print(s)
return "$LIBGCC", nil
}
return strings.Trim(string(f), "\r\n"), nil return strings.Trim(string(f), "\r\n"), nil
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment