Skip to content

Commit

Permalink
fix: allow setting boolean flags to false (#80)
Browse files Browse the repository at this point in the history
  • Loading branch information
natesales committed Dec 13, 2023
1 parent d72e2db commit 571e04e
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 0 deletions.
36 changes: 36 additions & 0 deletions cli/cli.go
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,42 @@ func SetDefaultTrueBools(opts *Flags) {
}
}

// SetFalseBooleans sets boolean flags to false from a given argument list and returns the remaining arguments
func SetFalseBooleans(opts *Flags, args []string) []string {
// Add equal signs to separated flags (e.g. --foo bar becomes --foo=bar)
for i, arg := range args {
if arg[0] == '-' && !strings.Contains(arg, "=") && i+1 < len(args) && args[i+1][0] != '-' {
args[i] = arg + "=" + args[i+1]
args = append(args[:i+1], args[i+2:]...)
}
}

var remainingArgs []string
for _, arg := range args {

if strings.HasSuffix(arg, "=true") || strings.HasSuffix(arg, "=false") {
flag := strings.ToLower(strings.TrimLeft(arg, "-"))
flag = strings.TrimSuffix(flag, "=true")
flag = strings.TrimSuffix(flag, "=false")

v := reflect.Indirect(reflect.ValueOf(opts))
vT := v.Type()
for i := 0; i < v.NumField(); i++ {
if vT.Field(i).Type == reflect.TypeOf(true) && (vT.Field(i).Tag.Get("long") == flag || vT.Field(i).Tag.Get("short") == flag) {
boolState := strings.HasSuffix(arg, "=true")
log.Tracef("Setting %s to %t", arg, boolState)
reflect.ValueOf(opts).Elem().Field(i).SetBool(boolState)
break
}
}
} else {
remainingArgs = append(remainingArgs, arg)
}
}

return remainingArgs
}

// ParseRRTypes parses a list of RR types in string format ("A", "AAAA", etc.) or integer format (1, 28, etc.)
func ParseRRTypes(t []string) (map[uint16]bool, error) {
rrTypes := make(map[uint16]bool, len(t))
Expand Down
1 change: 1 addition & 0 deletions main.go
Original file line number Diff line number Diff line change
Expand Up @@ -206,6 +206,7 @@ func parseServer(s string) (string, transport.Type, error) {

// driver is the "main" function for this program that accepts a flag slice for testing
func driver(args []string, out io.Writer) error {
args = cli.SetFalseBooleans(&opts, args)
parser := flags.NewParser(&opts, flags.Default)
parser.Usage = `[OPTIONS] [@server] [type...] [name]
Expand Down

0 comments on commit 571e04e

Please sign in to comment.