go ツールや git のようなコマンドラインツールには、それぞれにフラグのセットを持つ、多くのサブコマンドがあります。たとえば、go build と go get は、go ツールの異なる 2 つのサブコマンドです。flag パッケージを使用すると、独自のフラグを持つ、シンプルなサブコマンドを簡単に定義できます。
|
|
|

package main
|
|
import (
"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)
}
}
|