1 // Copyright 2017 The Go Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style
3 // license that can be found in the LICENSE file.
13 "cmd/go/internal/base"
14 "cmd/go/internal/cmdflag"
15 "cmd/go/internal/work"
20 // vetFlagDefn is the set of flags we process.
21 var vetFlagDefn = []*cmdflag.Defn{
22 // Note: Some flags, in particular -tags and -v, are known to
23 // vet but also defined as build flags. This works fine, so we
24 // don't define them here but use AddBuildFlags to init them.
25 // However some, like -x, are known to the build but not
26 // to vet. We handle them in vetFlags.
29 {Name: "all", BoolVar: new(bool)},
30 {Name: "asmdecl", BoolVar: new(bool)},
31 {Name: "assign", BoolVar: new(bool)},
32 {Name: "atomic", BoolVar: new(bool)},
33 {Name: "bool", BoolVar: new(bool)},
34 {Name: "buildtags", BoolVar: new(bool)},
35 {Name: "cgocall", BoolVar: new(bool)},
36 {Name: "composites", BoolVar: new(bool)},
37 {Name: "copylocks", BoolVar: new(bool)},
38 {Name: "httpresponse", BoolVar: new(bool)},
39 {Name: "lostcancel", BoolVar: new(bool)},
40 {Name: "methods", BoolVar: new(bool)},
41 {Name: "nilfunc", BoolVar: new(bool)},
42 {Name: "printf", BoolVar: new(bool)},
44 {Name: "rangeloops", BoolVar: new(bool)},
45 {Name: "shadow", BoolVar: new(bool)},
46 {Name: "shadowstrict", BoolVar: new(bool)},
47 {Name: "shift", BoolVar: new(bool)},
48 {Name: "source", BoolVar: new(bool)},
49 {Name: "structtags", BoolVar: new(bool)},
50 {Name: "tests", BoolVar: new(bool)},
51 {Name: "unreachable", BoolVar: new(bool)},
52 {Name: "unsafeptr", BoolVar: new(bool)},
53 {Name: "unusedfuncs"},
54 {Name: "unusedresult", BoolVar: new(bool)},
55 {Name: "unusedstringmethods"},
60 // add build flags to vetFlagDefn.
63 work.AddBuildFlags(&cmd)
64 cmd.Flag.StringVar(&vetTool, "vettool", "", "path to vet tool binary") // for cmd/vet tests; undocumented for now
65 cmd.Flag.VisitAll(func(f *flag.Flag) {
66 vetFlagDefn = append(vetFlagDefn, &cmdflag.Defn{
73 // vetFlags processes the command line, splitting it at the first non-flag
74 // into the list of flags and list of packages.
75 func vetFlags(args []string) (passToVet, packageNames []string) {
76 for i := 0; i < len(args); i++ {
77 if !strings.HasPrefix(args[i], "-") {
78 return args[:i], args[i:]
81 f, value, extraWord := cmdflag.Parse(cmd, vetFlagDefn, args, i)
83 fmt.Fprintf(os.Stderr, "vet: flag %q not defined\n", args[i])
84 fmt.Fprintf(os.Stderr, "Run \"go help vet\" for more information\n")
88 if err := f.Value.Set(value); err != nil {
89 base.Fatalf("invalid flag argument for -%s: %v", f.Name, err)
92 // Flags known to the build but not to vet, so must be dropped.
93 case "x", "n", "vettool", "compiler":
95 args = append(args[:i], args[i+2:]...)
98 args = append(args[:i], args[i+1:]...)