diff options
-rw-r--r-- | tools/nogo/build.go | 5 | ||||
-rw-r--r-- | tools/nogo/check/main.go | 8 | ||||
-rw-r--r-- | tools/nogo/defs.bzl | 4 | ||||
-rw-r--r-- | tools/nogo/nogo.go | 26 |
4 files changed, 31 insertions, 12 deletions
diff --git a/tools/nogo/build.go b/tools/nogo/build.go index 4067bb480..003533c71 100644 --- a/tools/nogo/build.go +++ b/tools/nogo/build.go @@ -31,3 +31,8 @@ func findStdPkg(GOOS, GOARCH, path string) (io.ReadCloser, error) { } return os.Open(fmt.Sprintf("external/go_sdk/pkg/%s_%s/%s.a", GOOS, GOARCH, path)) } + +// ReleaseTags returns nil, indicating that the defaults should be used. +func ReleaseTags() ([]string, error) { + return nil, nil +} diff --git a/tools/nogo/check/main.go b/tools/nogo/check/main.go index 0e7e92965..17ca0d846 100644 --- a/tools/nogo/check/main.go +++ b/tools/nogo/check/main.go @@ -66,14 +66,22 @@ func run([]string) int { return 1 } + releaseTags, err := nogo.ReleaseTags() + if err != nil { + fmt.Fprintf(os.Stderr, "error determining release tags: %v", err) + return 1 + } + // Run the configuration. if *stdlibFile != "" { // Perform stdlib analysis. c := loadConfig(*stdlibFile, new(nogo.StdlibConfig)).(*nogo.StdlibConfig) + c.ReleaseTags = releaseTags findings, factData, err = nogo.CheckStdlib(c, nogo.AllAnalyzers) } else if *packageFile != "" { // Perform standard analysis. c := loadConfig(*packageFile, new(nogo.PackageConfig)).(*nogo.PackageConfig) + c.ReleaseTags = releaseTags findings, factData, err = nogo.CheckPackage(c, nogo.AllAnalyzers, nil) } else { fmt.Fprintf(os.Stderr, "please provide at least one of package or stdlib!") diff --git a/tools/nogo/defs.bzl b/tools/nogo/defs.bzl index dc9a8b24e..bc0d6874f 100644 --- a/tools/nogo/defs.bzl +++ b/tools/nogo/defs.bzl @@ -126,7 +126,7 @@ def _nogo_stdlib_impl(ctx): Srcs = [f.path for f in go_ctx.stdlib_srcs], GOOS = go_ctx.goos, GOARCH = go_ctx.goarch, - Tags = go_ctx.gotags, + BuildTags = go_ctx.gotags, ) config_file = ctx.actions.declare_file(ctx.label.name + ".cfg") ctx.actions.write(config_file, config.to_json()) @@ -321,7 +321,7 @@ def _nogo_aspect_impl(target, ctx): NonGoFiles = [src.path for src in srcs if not src.path.endswith(".go")], GOOS = go_ctx.goos, GOARCH = go_ctx.goarch, - Tags = go_ctx.gotags, + BuildTags = go_ctx.gotags, FactMap = fact_map, ImportMap = import_map, StdlibFacts = stdlib_facts.path, diff --git a/tools/nogo/nogo.go b/tools/nogo/nogo.go index 2f88f84db..a96cb400a 100644 --- a/tools/nogo/nogo.go +++ b/tools/nogo/nogo.go @@ -52,10 +52,11 @@ import ( // // This contains everything required for stdlib analysis. type StdlibConfig struct { - Srcs []string - GOOS string - GOARCH string - Tags []string + Srcs []string + GOOS string + GOARCH string + BuildTags []string + ReleaseTags []string // Use build.Default if nil. } // PackageConfig is serialized as the configuration. @@ -65,7 +66,8 @@ type PackageConfig struct { ImportPath string GoFiles []string NonGoFiles []string - Tags []string + BuildTags []string + ReleaseTags []string // Use build.Default if nil. GOOS string GOARCH string ImportMap map[string]string @@ -182,7 +184,10 @@ func (c *PackageConfig) shouldInclude(path string) (bool, error) { ctx := build.Default ctx.GOOS = c.GOOS ctx.GOARCH = c.GOARCH - ctx.BuildTags = c.Tags + ctx.BuildTags = c.BuildTags + if c.ReleaseTags != nil { + ctx.ReleaseTags = c.ReleaseTags + } return ctx.MatchFile(filepath.Dir(path), filepath.Base(path)) } @@ -333,10 +338,11 @@ func CheckStdlib(config *StdlibConfig, analyzers []*analysis.Analyzer) (allFindi c, ok := packages[pkg] if !ok { c = &PackageConfig{ - ImportPath: pkg, - GOOS: config.GOOS, - GOARCH: config.GOARCH, - Tags: config.Tags, + ImportPath: pkg, + GOOS: config.GOOS, + GOARCH: config.GOARCH, + BuildTags: config.BuildTags, + ReleaseTags: config.ReleaseTags, } packages[pkg] = c } |