Command-Line Subcommands - 命令行子命令
命令行子命令 {.zh}
一些命令行工具,比如go工具或git有很多子命令,每个工具都有自己的set offlags。例如,go build和go get是go工具的两个不同的子命令.flag包让我们可以轻松定义具有自己标志的simplesubcommands。
package mainimport ("flag""fmt""os")func main() {
我们使用NewFlagSet函数声明一个子命令,然后继续定义特定于该子命令的新标志。
fooCmd := flag.NewFlagSet("foo", flag.ExitOnError)fooEnable := fooCmd.Bool("enable", false, "enable")fooName := fooCmd.String("name", "", "name")
对于不同的子命令,我们可以定义不同的支持标志。
barCmd := flag.NewFlagSet("bar", flag.ExitOnError)barLevel := barCmd.Int("level", 0, "level")
子命令被期望作为程序的第一个参数。
if len(os.Args) < 2 {fmt.Println("expected 'foo' or 'bar' subcommands")os.Exit(1)}
检查调用哪个子命令。
switch os.Args[1] {
对于每个子命令,我们解析自己的标志并可以访问尾随位置参数。
case "foo":fooCmd.Parse(os.Args[2:])fmt.Println("subcommand 'foo'")fmt.Println(" enable:", *fooEnable)fmt.Println(" name:", *fooName)fmt.Println(" tail:", fooCmd.Args())case "bar":barCmd.Parse(os.Args[2:])fmt.Println("subcommand 'bar'")fmt.Println(" level:", *barLevel)fmt.Println(" tail:", barCmd.Args())default:fmt.Println("expected 'foo' or 'bar' subcommands")os.Exit(1)}}
$ go build command-line-subcommands.go
首先调用foo子命令。
$ ./command-line-subcommands foo -enable -name=joe a1 a2subcommand 'foo'enable: truename: joetail: [a1 a2]
现在试试吧。
$ ./command-line-subcommands bar -level 8 a1subcommand 'bar'level: 8tail: [a1]
但 “bar” 不会接受foo 这个 flag。
$ ./command-line-subcommands bar -enable a1flag provided but not defined: -enableUsage of bar:-level intlevel
