package pflag // -- func Value type boolfuncValue func(string) error func (f boolfuncValue) Set(s string) error { return f(s) } func (f boolfuncValue) Type() string { return "boolfunc" } func (f boolfuncValue) String() string { return "" } // same behavior as stdlib 'flag' package func (f boolfuncValue) IsBoolFlag() bool { return true } // BoolFunc defines a func flag with specified name, callback function and usage string. // // The callback function will be called every time "--{name}" (or any form that matches the flag) is parsed // on the command line. func (f *FlagSet) BoolFunc(name string, usage string, fn func(string) error) { f.BoolFuncP(name, "", usage, fn) } // BoolFuncP is like BoolFunc, but accepts a shorthand letter that can be used after a single dash. func (f *FlagSet) BoolFuncP(name, shorthand string, usage string, fn func(string) error) { var val Value = boolfuncValue(fn) flag := f.VarPF(val, name, shorthand, usage) flag.NoOptDefVal = "true" } // BoolFunc defines a func flag with specified name, callback function and usage string. // // The callback function will be called every time "--{name}" (or any form that matches the flag) is parsed // on the command line. func BoolFunc(name string, usage string, fn func(string) error) { CommandLine.BoolFuncP(name, "", usage, fn) } // BoolFuncP is like BoolFunc, but accepts a shorthand letter that can be used after a single dash. func BoolFuncP(name, shorthand string, usage string, fn func(string) error) { CommandLine.BoolFuncP(name, shorthand, usage, fn) }