gobuild: pass user specified -C argument first (#3456)

The -C argument must come first on the command line of 'go build' if
the flags specified by the user via  build-flags start with -C pass it
first.

Replaces #3380
This commit is contained in:
Alessandro Arzilli 2023-08-15 00:37:57 +02:00 committed by GitHub
parent 4ce596b9dd
commit e56490e78f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 40 additions and 2 deletions

@ -61,13 +61,24 @@ func GoTestBuildCombinedOutput(debugname string, pkgs []string, buildflags strin
}
func goBuildArgs(debugname string, pkgs []string, buildflags string, isTest bool) []string {
args := []string{"-o", debugname}
var args []string
bfv := config.SplitQuotedFields(buildflags, '\'')
if len(bfv) >= 2 && bfv[0] == "-C" {
args = append(args, bfv[:2]...)
bfv = bfv[2:]
} else if len(bfv) >= 1 && strings.HasPrefix(bfv[0], "-C=") {
args = append(args, bfv[0])
bfv = bfv[1:]
}
args = append(args, "-o", debugname)
if isTest {
args = append([]string{"-c"}, args...)
}
args = append(args, "-gcflags", "all=-N -l")
if buildflags != "" {
args = append(args, config.SplitQuotedFields(buildflags, '\'')...)
args = append(args, bfv...)
}
args = append(args, pkgs...)
return args

@ -0,0 +1,27 @@
package gobuild
import (
"reflect"
"testing"
"github.com/go-delve/delve/pkg/config"
)
func TestGoBuildArgsDashC(t *testing.T) {
testCases := []struct{ in, tgt string }{
{"-C somedir", "-C somedir -o debug -gcflags 'all=-N -l' pkg"},
{"-C", "-o debug -gcflags 'all=-N -l' -C pkg"},
{"-C=somedir", "-C=somedir -o debug -gcflags 'all=-N -l' pkg"},
{"-C somedir -other -args", "-C somedir -o debug -gcflags 'all=-N -l' -other -args pkg"},
{"-C=somedir -other -args", "-C=somedir -o debug -gcflags 'all=-N -l' -other -args pkg"},
}
for _, tc := range testCases {
out := goBuildArgs("debug", []string{"pkg"}, tc.in, false)
tgt := config.SplitQuotedFields(tc.tgt, '\'')
t.Logf("%q -> %q", tc.in, out)
if !reflect.DeepEqual(out, tgt) {
t.Errorf("output mismatch input %q\noutput %q\ntarget %q", tc.in, out, tgt)
}
}
}