Commit 707cadd7 authored by Russ Cox's avatar Russ Cox

cmd/go: split out cmd/go/internal/clean,doc,fix,generate,list,run,tool,version,vet

This is one CL in a long sequence of changes to break up the
go command from one package into a plausible group of packages.

This sequence is concerned only with moving code, not changing
or cleaning up code. There will still be more cleanup after this sequence.

The entire sequence will be submitted together: it is not a goal
for the tree to build at every step.

For #18653.

Change-Id: Ib22fc435827d4a05a77a5200ac437ce00e2a4da3
Reviewed-on: https://go-review.googlesource.com/36204Reviewed-by: default avatarDavid Crawshaw <crawshaw@golang.org>
parent 76db88ab
This diff is collapsed.
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// 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.
package main package clean
import ( import (
"fmt" "fmt"
...@@ -17,7 +17,7 @@ import ( ...@@ -17,7 +17,7 @@ import (
"cmd/go/internal/work" "cmd/go/internal/work"
) )
var cmdClean = &base.Command{ var CmdClean = &base.Command{
UsageLine: "clean [-i] [-r] [-n] [-x] [build flags] [packages]", UsageLine: "clean [-i] [-r] [-n] [-x] [build flags] [packages]",
Short: "remove object files", Short: "remove object files",
Long: ` Long: `
...@@ -68,15 +68,15 @@ var cleanR bool // clean -r flag ...@@ -68,15 +68,15 @@ var cleanR bool // clean -r 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(&cleanR, "r", false, "") CmdClean.Flag.BoolVar(&cleanR, "r", false, "")
// -n and -x are important enough to be // -n and -x are important enough to be
// mentioned explicitly in the docs but they // mentioned explicitly in the docs but they
// are part of the build flags. // are part of the build flags.
work.AddBuildFlags(cmdClean) work.AddBuildFlags(CmdClean)
} }
func runClean(cmd *base.Command, args []string) { func runClean(cmd *base.Command, args []string) {
......
...@@ -2,16 +2,14 @@ ...@@ -2,16 +2,14 @@
// 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.
//go:generate ./mkalldocs.sh package doc
package main
import ( import (
"cmd/go/internal/base" "cmd/go/internal/base"
"cmd/go/internal/cfg" "cmd/go/internal/cfg"
) )
var cmdDoc = &base.Command{ var CmdDoc = &base.Command{
Run: runDoc, Run: runDoc,
UsageLine: "doc [-u] [-c] [package|[package.]symbol[.method]]", UsageLine: "doc [-u] [-c] [package|[package.]symbol[.method]]",
CustomFlags: true, CustomFlags: true,
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// 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.
package main package fix
import ( import (
"cmd/go/internal/base" "cmd/go/internal/base"
...@@ -11,7 +11,7 @@ import ( ...@@ -11,7 +11,7 @@ import (
"cmd/go/internal/str" "cmd/go/internal/str"
) )
var cmdFix = &base.Command{ var CmdFix = &base.Command{
Run: runFix, Run: runFix,
UsageLine: "fix [packages]", UsageLine: "fix [packages]",
Short: "run go tool fix on packages", Short: "run go tool fix on packages",
......
...@@ -2,15 +2,11 @@ ...@@ -2,15 +2,11 @@
// 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.
package main package generate
import ( import (
"bufio" "bufio"
"bytes" "bytes"
"cmd/go/internal/base"
"cmd/go/internal/cfg"
"cmd/go/internal/load"
"cmd/go/internal/work"
"fmt" "fmt"
"io" "io"
"log" "log"
...@@ -20,9 +16,14 @@ import ( ...@@ -20,9 +16,14 @@ import (
"regexp" "regexp"
"strconv" "strconv"
"strings" "strings"
"cmd/go/internal/base"
"cmd/go/internal/cfg"
"cmd/go/internal/load"
"cmd/go/internal/work"
) )
var cmdGenerate = &base.Command{ var CmdGenerate = &base.Command{
Run: runGenerate, Run: runGenerate,
UsageLine: "generate [-run regexp] [-n] [-v] [-x] [build flags] [file.go... | packages]", UsageLine: "generate [-run regexp] [-n] [-v] [-x] [build flags] [file.go... | packages]",
Short: "generate Go files by processing source", Short: "generate Go files by processing source",
...@@ -135,8 +136,8 @@ var ( ...@@ -135,8 +136,8 @@ var (
) )
func init() { func init() {
work.AddBuildFlags(cmdGenerate) work.AddBuildFlags(CmdGenerate)
cmdGenerate.Flag.StringVar(&generateRunFlag, "run", "", "") CmdGenerate.Flag.StringVar(&generateRunFlag, "run", "", "")
} }
func runGenerate(cmd *base.Command, args []string) { func runGenerate(cmd *base.Command, args []string) {
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// 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.
package main package generate
import ( import (
"reflect" "reflect"
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// 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.
package main package get
import ( import (
"cmd/go/internal/load" "cmd/go/internal/load"
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// 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.
package main package get
import "testing" import "testing"
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// 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.
package main package get
import ( import (
"errors" "errors"
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// 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.
package main package list
import ( import (
"go/build" "go/build"
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// 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.
package main package list
import ( import (
"bufio" "bufio"
...@@ -17,7 +17,7 @@ import ( ...@@ -17,7 +17,7 @@ import (
"text/template" "text/template"
) )
var cmdList = &base.Command{ var CmdList = &base.Command{
UsageLine: "list [-e] [-f format] [-json] [build flags] [packages]", UsageLine: "list [-e] [-f format] [-json] [build flags] [packages]",
Short: "list packages", Short: "list packages",
Long: ` Long: `
...@@ -140,13 +140,13 @@ For more about specifying packages, see 'go help packages'. ...@@ -140,13 +140,13 @@ 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
work.AddBuildFlags(cmdList) work.AddBuildFlags(CmdList)
} }
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 nl = []byte{'\n'} var nl = []byte{'\n'}
func runList(cmd *base.Command, args []string) { func runList(cmd *base.Command, args []string) {
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// 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.
package main package run
import ( import (
"fmt" "fmt"
...@@ -16,7 +16,7 @@ import ( ...@@ -16,7 +16,7 @@ import (
"cmd/go/internal/work" "cmd/go/internal/work"
) )
var cmdRun = &base.Command{ var CmdRun = &base.Command{
UsageLine: "run [build flags] [-exec xprog] gofiles... [arguments...]", UsageLine: "run [build flags] [-exec xprog] gofiles... [arguments...]",
Short: "compile and run Go program", Short: "compile and run Go program",
Long: ` Long: `
...@@ -40,10 +40,10 @@ See also: go build. ...@@ -40,10 +40,10 @@ See also: go build.
} }
func init() { func init() {
cmdRun.Run = runRun // break init loop CmdRun.Run = runRun // break init loop
work.AddBuildFlags(cmdRun) work.AddBuildFlags(CmdRun)
cmdRun.Flag.Var((*base.StringsFlag)(&work.ExecCmd), "exec", "") CmdRun.Flag.Var((*base.StringsFlag)(&work.ExecCmd), "exec", "")
} }
func printStderr(args ...interface{}) (int, error) { func printStderr(args ...interface{}) (int, error) {
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// 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.
package main package tool
import ( import (
"fmt" "fmt"
...@@ -15,7 +15,7 @@ import ( ...@@ -15,7 +15,7 @@ import (
"cmd/go/internal/cfg" "cmd/go/internal/cfg"
) )
var cmdTool = &base.Command{ var CmdTool = &base.Command{
Run: runTool, Run: runTool,
UsageLine: "tool [-n] command [args...]", UsageLine: "tool [-n] command [args...]",
Short: "run specified go tool", Short: "run specified go tool",
...@@ -33,7 +33,7 @@ For more about each tool command, see 'go tool command -h'. ...@@ -33,7 +33,7 @@ For more about each tool command, see 'go tool command -h'.
var toolN bool var toolN bool
func init() { func init() {
cmdTool.Flag.BoolVar(&toolN, "n", false, "") CmdTool.Flag.BoolVar(&toolN, "n", false, "")
} }
func runTool(cmd *base.Command, args []string) { func runTool(cmd *base.Command, args []string) {
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// 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.
package main package version
import ( import (
"cmd/go/internal/base" "cmd/go/internal/base"
...@@ -10,7 +10,7 @@ import ( ...@@ -10,7 +10,7 @@ import (
"runtime" "runtime"
) )
var cmdVersion = &base.Command{ var CmdVersion = &base.Command{
Run: runVersion, Run: runVersion,
UsageLine: "version", UsageLine: "version",
Short: "print Go version", Short: "print Go version",
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// 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.
package main package vet
import ( import (
"path/filepath" "path/filepath"
...@@ -15,10 +15,10 @@ import ( ...@@ -15,10 +15,10 @@ import (
) )
func init() { func init() {
work.AddBuildFlags(cmdVet) work.AddBuildFlags(CmdVet)
} }
var cmdVet = &base.Command{ var CmdVet = &base.Command{
Run: runVet, Run: runVet,
UsageLine: "vet [-n] [-x] [build flags] [packages]", UsageLine: "vet [-n] [-x] [build flags] [packages]",
Short: "run go tool vet on packages", Short: "run go tool vet on packages",
......
...@@ -2,6 +2,8 @@ ...@@ -2,6 +2,8 @@
// 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.
//go:generate ./mkalldocs.sh
package main package main
import ( import (
...@@ -16,32 +18,41 @@ import ( ...@@ -16,32 +18,41 @@ import (
"cmd/go/internal/base" "cmd/go/internal/base"
"cmd/go/internal/bug" "cmd/go/internal/bug"
"cmd/go/internal/cfg" "cmd/go/internal/cfg"
"cmd/go/internal/clean"
"cmd/go/internal/doc"
"cmd/go/internal/env" "cmd/go/internal/env"
"cmd/go/internal/fix"
fmtcmd "cmd/go/internal/fmt" fmtcmd "cmd/go/internal/fmt"
"cmd/go/internal/generate"
"cmd/go/internal/get" "cmd/go/internal/get"
"cmd/go/internal/help" "cmd/go/internal/help"
"cmd/go/internal/list"
"cmd/go/internal/run"
"cmd/go/internal/test" "cmd/go/internal/test"
"cmd/go/internal/tool"
"cmd/go/internal/version"
"cmd/go/internal/vet"
"cmd/go/internal/work" "cmd/go/internal/work"
) )
func init() { func init() {
base.Commands = []*base.Command{ base.Commands = []*base.Command{
work.CmdBuild, work.CmdBuild,
cmdClean, clean.CmdClean,
cmdDoc, doc.CmdDoc,
env.CmdEnv, env.CmdEnv,
bug.CmdBug, bug.CmdBug,
cmdFix, fix.CmdFix,
fmtcmd.CmdFmt, fmtcmd.CmdFmt,
cmdGenerate, generate.CmdGenerate,
get.CmdGet, get.CmdGet,
work.CmdInstall, work.CmdInstall,
cmdList, list.CmdList,
cmdRun, run.CmdRun,
test.CmdTest, test.CmdTest,
cmdTool, tool.CmdTool,
cmdVersion, version.CmdVersion,
cmdVet, vet.CmdVet,
help.HelpC, help.HelpC,
help.HelpBuildmode, help.HelpBuildmode,
...@@ -130,8 +141,6 @@ func main() { ...@@ -130,8 +141,6 @@ func main() {
base.Exit() base.Exit()
} }
var usage func()
func init() { func init() {
base.Usage = mainUsage base.Usage = mainUsage
} }
......
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