mirror of
https://github.com/containers/skopeo.git
synced 2025-09-17 07:19:37 +00:00
41 lines
1.5 KiB
Go
41 lines
1.5 KiB
Go
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)
|
|
}
|