我现在有一个非常基本的CLI应用程序,可以使用flag
库。它接受两个标志,并简单地将值打印到终端上
$ ./hello --flag1 v1 --flag2 v2
v1
v2
如果说我不小心设置了flag2
,但忘记提供该值,则它预期显示一条错误消息
$ ./hello --flag1 v1 --flag2
flag needs an argument: -flag2
Usage of ./hello:
-flag1 string
usage1 (default "value1")
-flag2 string
usage3 (default "value2")
但是,如果我设置flag1
,不为其提供值,然后设置flag2
,则没有错误
$ ./hello --flag1 --flag2 v2
--flag2
value2
让我感到奇怪的是,flag1
会使用flag2
的名称作为值,更不用说flag2
甚至没有获得所提供的值。我希望结果是类似于设置flag2
且未提供任何值的错误消息。
这是图书馆的限制吗?还是这是一个错误?
是否有办法使其正确解析,还是我必须添加自己的自定义解析逻辑?
要复制的最小代码:
package main
import (
"flag"
"fmt"
)
func main() {
flag1 := flag.String("flag1", "value1", "usage1")
flag2 := flag.String("flag2", "value2", "usage3")
flag.Parse()
fmt.Println(*flag1)
fmt.Println(*flag2)
}
答案 0 :(得分:1)
如果希望""
为空字符串,则必须使用flag2
对其进行显式设置。
$ ./hello --flag1 v1 --flag2 ""
对于另一个问题,当您指定flag1
时,后面的所有内容都是字符串值。所以当您使用时听起来并不奇怪
$ ./hello --flag1 --flag2
然后flag1
的值为“ flag2”,因为它与您这样写的相同:
$ ./hello --flag1="--flag2"
顺便说一句,您不必为其指定值的标志类型为bool
。仅将标志指定为true
就足够了。