Command-line flags
are a common way to specify options for command-line
programs. For example, in |
|
![]() ![]() package main |
|
Go provides a |
import ( "flag" "fmt" ) |
func main() { |
|
Basic flag declarations are available for string,
integer, and boolean options. Here we declare a
string flag |
wordPtr := flag.String("word", "foo", "a string") |
This declares |
numbPtr := flag.Int("numb", 42, "an int") forkPtr := flag.Bool("fork", false, "a bool") |
It’s also possible to declare an option that uses an existing var declared elsewhere in the program. Note that we need to pass in a pointer to the flag declaration function. |
var svar string flag.StringVar(&svar, "svar", "bar", "a string var") |
Once all flags are declared, call |
flag.Parse() |
Here we’ll just dump out the parsed options and
any trailing positional arguments. Note that we
need to dereference the pointers with e.g. |
fmt.Println("word:", *wordPtr) fmt.Println("numb:", *numbPtr) fmt.Println("fork:", *forkPtr) fmt.Println("svar:", svar) fmt.Println("tail:", flag.Args()) } |
To experiment with the command-line flags program it’s best to first compile it and then run the resulting binary directly. |
$ go build command-line-flags.go
|
Try out the built program by first giving it values for all flags. |
$ ./command-line-flags -word=opt -numb=7 -fork -svar=flag word: opt numb: 7 fork: true svar: flag tail: [] |
Note that if you omit flags they automatically take their default values. |
$ ./command-line-flags -word=opt word: opt numb: 42 fork: false svar: bar tail: [] |
Trailing positional arguments can be provided after any flags. |
$ ./command-line-flags -word=opt a1 a2 a3 word: opt ... tail: [a1 a2 a3] |
Note that the |
$ ./command-line-flags -word=opt a1 a2 a3 -numb=7 word: opt numb: 42 fork: false svar: bar tail: [a1 a2 a3 -numb=7] |
Use |
$ ./command-line-flags -h Usage of ./command-line-flags: -fork=false: a bool -numb=42: an int -svar="bar": a string var -word="foo": a string |
If you provide a flag that wasn’t specified to the
|
$ ./command-line-flags -wat flag provided but not defined: -wat Usage of ./command-line-flags: ... |
Next example: Command-Line Subcommands.