Commit 0f52fdbf authored by Russ Cox's avatar Russ Cox

cmd/go: accept build flags in clean and list

list has been adding them one at a time haphazardly
(race and tags were there and documented; compiler
was there and undocumented).

clean -i needs -compiler in order to clean the
installed targets for alternate compilers.

Fixes #7302.

While we're here, tweak the language in the 'go get' docs
about build flags.

Fixes #7807.

LGTM=iant
R=golang-codereviews, iant
CC=golang-codereviews
https://golang.org/cl/99130043
parent 2182d578
...@@ -52,7 +52,8 @@ name is the base name of the containing directory. ...@@ -52,7 +52,8 @@ name is the base name of the containing directory.
The -i flag installs the packages that are dependencies of the target. The -i flag installs the packages that are dependencies of the target.
The build flags are shared by the build, install, run, and test commands: The build flags are shared by the build, clean, get, install, list, run,
and test commands:
-a -a
force rebuilding of packages that are already up-to-date. force rebuilding of packages that are already up-to-date.
...@@ -164,7 +165,8 @@ func init() { ...@@ -164,7 +165,8 @@ func init() {
} }
} }
// addBuildFlags adds the flags common to the build and install commands. // addBuildFlags adds the flags common to the build, clean, get,
// install, list, run, and test commands.
func addBuildFlags(cmd *Command) { func addBuildFlags(cmd *Command) {
// NOTE: If you add flags here, also add them to testflag.go. // NOTE: If you add flags here, also add them to testflag.go.
cmd.Flag.BoolVar(&buildA, "a", false, "") cmd.Flag.BoolVar(&buildA, "a", false, "")
......
...@@ -13,7 +13,7 @@ import ( ...@@ -13,7 +13,7 @@ import (
) )
var cmdClean = &Command{ var cmdClean = &Command{
UsageLine: "clean [-i] [-r] [-n] [-x] [packages]", UsageLine: "clean [-i] [-r] [-n] [-x] [build flags] [packages]",
Short: "remove object files", Short: "remove object files",
Long: ` Long: `
Clean removes object files from package source directories. Clean removes object files from package source directories.
...@@ -52,23 +52,26 @@ dependencies of the packages named by the import paths. ...@@ -52,23 +52,26 @@ dependencies of the packages named by the import paths.
The -x flag causes clean to print remove commands as it executes them. The -x flag causes clean to print remove commands as it executes them.
For more about build flags, see 'go help build'.
For more about specifying packages, see 'go help packages'. For more about specifying packages, see 'go help packages'.
`, `,
} }
var cleanI bool // clean -i flag var cleanI bool // clean -i flag
var cleanN bool // clean -n flag
var cleanR bool // clean -r flag var cleanR bool // clean -r flag
var cleanX bool // clean -x flag
func init() { func init() {
// break init cycle // break init cycle
cmdClean.Run = runClean cmdClean.Run = runClean
cmdClean.Flag.BoolVar(&cleanI, "i", false, "") cmdClean.Flag.BoolVar(&cleanI, "i", false, "")
cmdClean.Flag.BoolVar(&cleanN, "n", false, "")
cmdClean.Flag.BoolVar(&cleanR, "r", false, "") cmdClean.Flag.BoolVar(&cleanR, "r", false, "")
cmdClean.Flag.BoolVar(&cleanX, "x", false, "") // -n and -x are important enough to be
// mentioned explicitly in the docs but they
// are part of the build flags.
addBuildFlags(cmdClean)
} }
func runClean(cmd *Command, args []string) { func runClean(cmd *Command, args []string) {
...@@ -169,7 +172,7 @@ func clean(p *Package) { ...@@ -169,7 +172,7 @@ func clean(p *Package) {
} }
} }
if cleanN || cleanX { if buildN || buildX {
b.showcmd(p.Dir, "rm -f %s", strings.Join(allRemove, " ")) b.showcmd(p.Dir, "rm -f %s", strings.Join(allRemove, " "))
} }
...@@ -182,9 +185,9 @@ func clean(p *Package) { ...@@ -182,9 +185,9 @@ func clean(p *Package) {
if dir.IsDir() { if dir.IsDir() {
// TODO: Remove once Makefiles are forgotten. // TODO: Remove once Makefiles are forgotten.
if cleanDir[name] { if cleanDir[name] {
if cleanN || cleanX { if buildN || buildX {
b.showcmd(p.Dir, "rm -r %s", name) b.showcmd(p.Dir, "rm -r %s", name)
if cleanN { if buildN {
continue continue
} }
} }
...@@ -195,7 +198,7 @@ func clean(p *Package) { ...@@ -195,7 +198,7 @@ func clean(p *Package) {
continue continue
} }
if cleanN { if buildN {
continue continue
} }
...@@ -205,10 +208,10 @@ func clean(p *Package) { ...@@ -205,10 +208,10 @@ func clean(p *Package) {
} }
if cleanI && p.target != "" { if cleanI && p.target != "" {
if cleanN || cleanX { if buildN || buildX {
b.showcmd("", "rm -f %s", p.target) b.showcmd("", "rm -f %s", p.target)
} }
if !cleanN { if !buildN {
removeFile(p.target) removeFile(p.target)
} }
} }
...@@ -218,10 +221,10 @@ func clean(p *Package) { ...@@ -218,10 +221,10 @@ func clean(p *Package) {
dir := p.swigDir(&buildContext) dir := p.swigDir(&buildContext)
soname := p.swigSoname(f) soname := p.swigSoname(f)
target := filepath.Join(dir, soname) target := filepath.Join(dir, soname)
if cleanN || cleanX { if buildN || buildX {
b.showcmd("", "rm -f %s", target) b.showcmd("", "rm -f %s", target)
} }
if !cleanN { if !buildN {
removeFile(target) removeFile(target)
} }
} }
......
...@@ -46,7 +46,7 @@ Compile packages and dependencies ...@@ -46,7 +46,7 @@ Compile packages and dependencies
Usage: Usage:
go build [-o output] [build flags] [packages] go build [-o output] [-i] [build flags] [packages]
Build compiles the packages named by the import paths, Build compiles the packages named by the import paths,
along with their dependencies, but it does not install the results. along with their dependencies, but it does not install the results.
...@@ -67,6 +67,8 @@ derives from the first file name mentioned, such as f1 for 'go build ...@@ -67,6 +67,8 @@ derives from the first file name mentioned, such as f1 for 'go build
f1.go f2.go'; with no files provided ('go build'), the output file f1.go f2.go'; with no files provided ('go build'), the output file
name is the base name of the containing directory. name is the base name of the containing directory.
The -i flag installs the packages that are dependencies of the target.
The build flags are shared by the build, install, run, and test commands: The build flags are shared by the build, install, run, and test commands:
-a -a
...@@ -122,7 +124,7 @@ Remove object files ...@@ -122,7 +124,7 @@ Remove object files
Usage: Usage:
go clean [-i] [-r] [-n] [-x] [packages] go clean [-i] [-r] [-n] [-x] [build flags] [packages]
Clean removes object files from package source directories. Clean removes object files from package source directories.
The go command builds most objects in a temporary directory, The go command builds most objects in a temporary directory,
...@@ -160,6 +162,8 @@ dependencies of the packages named by the import paths. ...@@ -160,6 +162,8 @@ dependencies of the packages named by the import paths.
The -x flag causes clean to print remove commands as it executes them. The -x flag causes clean to print remove commands as it executes them.
For more about build flags, see 'go help build'.
For more about specifying packages, see 'go help packages'. For more about specifying packages, see 'go help packages'.
...@@ -271,7 +275,7 @@ List packages ...@@ -271,7 +275,7 @@ List packages
Usage: Usage:
go list [-e] [-race] [-f format] [-json] [-tags 'tag list'] [packages] go list [-e] [-f format] [-json] [build flags] [packages]
List lists the packages named by the import paths, one per line. List lists the packages named by the import paths, one per line.
...@@ -364,11 +368,7 @@ printing. Erroneous packages will have a non-empty ImportPath and ...@@ -364,11 +368,7 @@ printing. Erroneous packages will have a non-empty ImportPath and
a non-nil Error field; other information may or may not be missing a non-nil Error field; other information may or may not be missing
(zeroed). (zeroed).
The -tags flag specifies a list of build tags, like in the 'go build' For more about build flags, see 'go help build'.
command.
The -race flag causes the package data to include the dependencies
required by the race detector.
For more about specifying packages, see 'go help packages'. For more about specifying packages, see 'go help packages'.
......
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
// Use of this source code is governed by a BSD-style // Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file. // license that can be found in the LICENSE file.
// TODO: Dashboard upload
package main package main
import ( import (
...@@ -37,8 +35,7 @@ The -u flag instructs get to use the network to update the named packages ...@@ -37,8 +35,7 @@ The -u flag instructs get to use the network to update the named packages
and their dependencies. By default, get uses the network to check out and their dependencies. By default, get uses the network to check out
missing packages but does not use it to look for updates to existing packages. missing packages but does not use it to look for updates to existing packages.
Get also accepts all the flags in the 'go build' and 'go install' commands, Get also accepts build flags to control the installation. See 'go help build'.
to control the installation. See 'go help build'.
When checking out or updating a package, get looks for a branch or tag When checking out or updating a package, get looks for a branch or tag
that matches the locally installed version of Go. The most important that matches the locally installed version of Go. The most important
......
...@@ -14,7 +14,7 @@ import ( ...@@ -14,7 +14,7 @@ import (
) )
var cmdList = &Command{ var cmdList = &Command{
UsageLine: "list [-e] [-race] [-f format] [-json] [-tags 'tag list'] [packages]", UsageLine: "list [-e] [-f format] [-json] [build flags] [packages]",
Short: "list packages", Short: "list packages",
Long: ` Long: `
List lists the packages named by the import paths, one per line. List lists the packages named by the import paths, one per line.
...@@ -108,11 +108,7 @@ printing. Erroneous packages will have a non-empty ImportPath and ...@@ -108,11 +108,7 @@ printing. Erroneous packages will have a non-empty ImportPath and
a non-nil Error field; other information may or may not be missing a non-nil Error field; other information may or may not be missing
(zeroed). (zeroed).
The -tags flag specifies a list of build tags, like in the 'go build' For more about build flags, see 'go help build'.
command.
The -race flag causes the package data to include the dependencies
required by the race detector.
For more about specifying packages, see 'go help packages'. For more about specifying packages, see 'go help packages'.
`, `,
...@@ -120,24 +116,18 @@ For more about specifying packages, see 'go help packages'. ...@@ -120,24 +116,18 @@ For more about specifying packages, see 'go help packages'.
func init() { func init() {
cmdList.Run = runList // break init cycle cmdList.Run = runList // break init cycle
cmdList.Flag.Var(buildCompiler{}, "compiler", "") addBuildFlags(cmdList)
cmdList.Flag.Var((*stringsFlag)(&buildContext.BuildTags), "tags", "")
} }
var listE = cmdList.Flag.Bool("e", false, "") var listE = cmdList.Flag.Bool("e", false, "")
var listFmt = cmdList.Flag.String("f", "{{.ImportPath}}", "") var listFmt = cmdList.Flag.String("f", "{{.ImportPath}}", "")
var listJson = cmdList.Flag.Bool("json", false, "") var listJson = cmdList.Flag.Bool("json", false, "")
var listRace = cmdList.Flag.Bool("race", false, "")
var nl = []byte{'\n'} var nl = []byte{'\n'}
func runList(cmd *Command, args []string) { func runList(cmd *Command, args []string) {
out := newTrackingWriter(os.Stdout) out := newTrackingWriter(os.Stdout)
defer out.w.Flush() defer out.w.Flush()
if *listRace {
buildRace = true
}
var do func(*Package) var do func(*Package)
if *listJson { if *listJson {
do = func(p *Package) { do = func(p *Package) {
......
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