Is it possible not to set default value in flag package in Go? For example, in flag package you can write out the following line:
filename := flag.String("file", "test.csv", "Filename to cope with")
In the above code, I don't want to necessarily set default value, which is test.csv
in this case, and instead always make users specify their own filename, and if it's not specified then I want to cause an error and exit the program.
One of the way I came up with is that I first check the value of filename
after doing flag.Parse()
, and if that value is test.csv
then I have the program exits with the appropriate error message. However, I don't want to write such redundant code if it can be evaded - and even if it can't, I'd like to hear any better way to cope with the issue here.
You can do those kind of operations in Python's argparse
module by the way - I just want to implement the similar thing if I can...
Also, can I implement both short and long arguments (in other words both -f
and -file
argument?) in flag package?
Thanks.
I think it's idiomatic to design your flag values in such a way which implies "not present" when equal to the zero value of their respective types. For example:
optFile := flag.String("file", "", "Source file")
flag.Parse()
fn := *optFile
if fn == "" {
fn = "/dev/stdin"
}
f, err := os.Open(fn)
...
Ad the 2nd question: IINM, the flag package by design doesn't distinguish between -flag
and --flag
. IOW, you can have both -f
and --file
in your flag set and write any version of -
or --
before both f
and file
. However, considering another defined flag -g
, the flag package will not recognize -gf foo
as being equvalent of -g -f foo
.
When I have a flag that cannot have a default value I often use the value REQUIRED
or something similar. I find this makes the --help
easier to read.
As for why it wasn't baked in, I suspect it just wasn't considered important enough. The default wouldn't fit every need. However, the --help
flag is similar; it doesn't fit every need, but it's good enough most of the time.
That's not to say the required flags are a bad idea. If you're passionate enough a flagutil
package could be nice. Wrap the current flag
api, make Parse
return an error that describes the missing flag and add a RequiredInt
and RequiredIntVar
etc. If it turns out to be useful / popular it could be merged with the official flag
package.