commit
2e0e39a03b
@ -72,7 +72,7 @@ func (f *GenericFlag) ApplyInputSourceValue(context *cli.Context, isc InputSourc
|
|||||||
}
|
}
|
||||||
if value != nil {
|
if value != nil {
|
||||||
eachName(f.Name, func(name string) {
|
eachName(f.Name, func(name string) {
|
||||||
f.set.Set(f.Name, value.String())
|
_ = f.set.Set(f.Name, value.String())
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -135,7 +135,7 @@ func (f *BoolFlag) ApplyInputSourceValue(context *cli.Context, isc InputSourceCo
|
|||||||
}
|
}
|
||||||
if value {
|
if value {
|
||||||
eachName(f.Name, func(name string) {
|
eachName(f.Name, func(name string) {
|
||||||
f.set.Set(f.Name, strconv.FormatBool(value))
|
_ = f.set.Set(f.Name, strconv.FormatBool(value))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -153,7 +153,7 @@ func (f *BoolTFlag) ApplyInputSourceValue(context *cli.Context, isc InputSourceC
|
|||||||
}
|
}
|
||||||
if !value {
|
if !value {
|
||||||
eachName(f.Name, func(name string) {
|
eachName(f.Name, func(name string) {
|
||||||
f.set.Set(f.Name, strconv.FormatBool(value))
|
_ = f.set.Set(f.Name, strconv.FormatBool(value))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -171,7 +171,7 @@ func (f *StringFlag) ApplyInputSourceValue(context *cli.Context, isc InputSource
|
|||||||
}
|
}
|
||||||
if value != "" {
|
if value != "" {
|
||||||
eachName(f.Name, func(name string) {
|
eachName(f.Name, func(name string) {
|
||||||
f.set.Set(f.Name, value)
|
_ = f.set.Set(f.Name, value)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -189,7 +189,7 @@ func (f *IntFlag) ApplyInputSourceValue(context *cli.Context, isc InputSourceCon
|
|||||||
}
|
}
|
||||||
if value > 0 {
|
if value > 0 {
|
||||||
eachName(f.Name, func(name string) {
|
eachName(f.Name, func(name string) {
|
||||||
f.set.Set(f.Name, strconv.FormatInt(int64(value), 10))
|
_ = f.set.Set(f.Name, strconv.FormatInt(int64(value), 10))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -207,7 +207,7 @@ func (f *DurationFlag) ApplyInputSourceValue(context *cli.Context, isc InputSour
|
|||||||
}
|
}
|
||||||
if value > 0 {
|
if value > 0 {
|
||||||
eachName(f.Name, func(name string) {
|
eachName(f.Name, func(name string) {
|
||||||
f.set.Set(f.Name, value.String())
|
_ = f.set.Set(f.Name, value.String())
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -226,7 +226,7 @@ func (f *Float64Flag) ApplyInputSourceValue(context *cli.Context, isc InputSourc
|
|||||||
if value > 0 {
|
if value > 0 {
|
||||||
floatStr := float64ToString(value)
|
floatStr := float64ToString(value)
|
||||||
eachName(f.Name, func(name string) {
|
eachName(f.Name, func(name string) {
|
||||||
f.set.Set(f.Name, floatStr)
|
_ = f.set.Set(f.Name, floatStr)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -239,30 +239,30 @@ func TestDurationApplyInputSourceMethodSet(t *testing.T) {
|
|||||||
c := runTest(t, testApplyInputSource{
|
c := runTest(t, testApplyInputSource{
|
||||||
Flag: NewDurationFlag(cli.DurationFlag{Name: "test"}),
|
Flag: NewDurationFlag(cli.DurationFlag{Name: "test"}),
|
||||||
FlagName: "test",
|
FlagName: "test",
|
||||||
MapValue: time.Duration(30 * time.Second),
|
MapValue: 30 * time.Second,
|
||||||
})
|
})
|
||||||
expect(t, time.Duration(30*time.Second), c.Duration("test"))
|
expect(t, 30*time.Second, c.Duration("test"))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDurationApplyInputSourceMethodContextSet(t *testing.T) {
|
func TestDurationApplyInputSourceMethodContextSet(t *testing.T) {
|
||||||
c := runTest(t, testApplyInputSource{
|
c := runTest(t, testApplyInputSource{
|
||||||
Flag: NewDurationFlag(cli.DurationFlag{Name: "test"}),
|
Flag: NewDurationFlag(cli.DurationFlag{Name: "test"}),
|
||||||
FlagName: "test",
|
FlagName: "test",
|
||||||
MapValue: time.Duration(30 * time.Second),
|
MapValue: 30 * time.Second,
|
||||||
ContextValueString: time.Duration(15 * time.Second).String(),
|
ContextValueString: (15 * time.Second).String(),
|
||||||
})
|
})
|
||||||
expect(t, time.Duration(15*time.Second), c.Duration("test"))
|
expect(t, 15*time.Second, c.Duration("test"))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDurationApplyInputSourceMethodEnvVarSet(t *testing.T) {
|
func TestDurationApplyInputSourceMethodEnvVarSet(t *testing.T) {
|
||||||
c := runTest(t, testApplyInputSource{
|
c := runTest(t, testApplyInputSource{
|
||||||
Flag: NewDurationFlag(cli.DurationFlag{Name: "test", EnvVar: "TEST"}),
|
Flag: NewDurationFlag(cli.DurationFlag{Name: "test", EnvVar: "TEST"}),
|
||||||
FlagName: "test",
|
FlagName: "test",
|
||||||
MapValue: time.Duration(30 * time.Second),
|
MapValue: 30 * time.Second,
|
||||||
EnvVarName: "TEST",
|
EnvVarName: "TEST",
|
||||||
EnvVarValue: time.Duration(15 * time.Second).String(),
|
EnvVarValue: (15 * time.Second).String(),
|
||||||
})
|
})
|
||||||
expect(t, time.Duration(15*time.Second), c.Duration("test"))
|
expect(t, 15*time.Second, c.Duration("test"))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFloat64ApplyInputSourceMethodSet(t *testing.T) {
|
func TestFloat64ApplyInputSourceMethodSet(t *testing.T) {
|
||||||
@ -300,19 +300,19 @@ func runTest(t *testing.T, test testApplyInputSource) *cli.Context {
|
|||||||
set := flag.NewFlagSet(test.FlagSetName, flag.ContinueOnError)
|
set := flag.NewFlagSet(test.FlagSetName, flag.ContinueOnError)
|
||||||
c := cli.NewContext(nil, set, nil)
|
c := cli.NewContext(nil, set, nil)
|
||||||
if test.EnvVarName != "" && test.EnvVarValue != "" {
|
if test.EnvVarName != "" && test.EnvVarValue != "" {
|
||||||
os.Setenv(test.EnvVarName, test.EnvVarValue)
|
_ = os.Setenv(test.EnvVarName, test.EnvVarValue)
|
||||||
defer os.Setenv(test.EnvVarName, "")
|
defer os.Setenv(test.EnvVarName, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
test.Flag.Apply(set)
|
test.Flag.Apply(set)
|
||||||
if test.ContextValue != nil {
|
if test.ContextValue != nil {
|
||||||
flag := set.Lookup(test.FlagName)
|
f := set.Lookup(test.FlagName)
|
||||||
flag.Value = test.ContextValue
|
f.Value = test.ContextValue
|
||||||
}
|
}
|
||||||
if test.ContextValueString != "" {
|
if test.ContextValueString != "" {
|
||||||
set.Set(test.FlagName, test.ContextValueString)
|
_ = set.Set(test.FlagName, test.ContextValueString)
|
||||||
}
|
}
|
||||||
test.Flag.ApplyInputSourceValue(c, inputSource)
|
_ = test.Flag.ApplyInputSourceValue(c, inputSource)
|
||||||
|
|
||||||
return c
|
return c
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,7 @@ func TestCommandJSONFileTest(t *testing.T) {
|
|||||||
app := cli.NewApp()
|
app := cli.NewApp()
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
test := []string{"test-cmd", "--load", fileName}
|
test := []string{"test-cmd", "--load", fileName}
|
||||||
set.Parse(test)
|
_ = set.Parse(test)
|
||||||
|
|
||||||
c := cli.NewContext(app, set, nil)
|
c := cli.NewContext(app, set, nil)
|
||||||
|
|
||||||
@ -52,11 +52,11 @@ func TestCommandJSONFileTestGlobalEnvVarWins(t *testing.T) {
|
|||||||
|
|
||||||
app := cli.NewApp()
|
app := cli.NewApp()
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
os.Setenv("THE_TEST", "10")
|
_ = os.Setenv("THE_TEST", "10")
|
||||||
defer os.Setenv("THE_TEST", "")
|
defer os.Setenv("THE_TEST", "")
|
||||||
|
|
||||||
test := []string{"test-cmd", "--load", fileName}
|
test := []string{"test-cmd", "--load", fileName}
|
||||||
set.Parse(test)
|
_ = set.Parse(test)
|
||||||
|
|
||||||
c := cli.NewContext(app, set, nil)
|
c := cli.NewContext(app, set, nil)
|
||||||
|
|
||||||
@ -87,11 +87,11 @@ func TestCommandJSONFileTestGlobalEnvVarWinsNested(t *testing.T) {
|
|||||||
|
|
||||||
app := cli.NewApp()
|
app := cli.NewApp()
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
os.Setenv("THE_TEST", "10")
|
_ = os.Setenv("THE_TEST", "10")
|
||||||
defer os.Setenv("THE_TEST", "")
|
defer os.Setenv("THE_TEST", "")
|
||||||
|
|
||||||
test := []string{"test-cmd", "--load", fileName}
|
test := []string{"test-cmd", "--load", fileName}
|
||||||
set.Parse(test)
|
_ = set.Parse(test)
|
||||||
|
|
||||||
c := cli.NewContext(app, set, nil)
|
c := cli.NewContext(app, set, nil)
|
||||||
|
|
||||||
@ -123,7 +123,7 @@ func TestCommandJSONFileTestSpecifiedFlagWins(t *testing.T) {
|
|||||||
app := cli.NewApp()
|
app := cli.NewApp()
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
test := []string{"test-cmd", "--load", fileName, "--test", "7"}
|
test := []string{"test-cmd", "--load", fileName, "--test", "7"}
|
||||||
set.Parse(test)
|
_ = set.Parse(test)
|
||||||
|
|
||||||
c := cli.NewContext(app, set, nil)
|
c := cli.NewContext(app, set, nil)
|
||||||
|
|
||||||
@ -155,7 +155,7 @@ func TestCommandJSONFileTestSpecifiedFlagWinsNested(t *testing.T) {
|
|||||||
app := cli.NewApp()
|
app := cli.NewApp()
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
test := []string{"test-cmd", "--load", fileName, "--top.test", "7"}
|
test := []string{"test-cmd", "--load", fileName, "--top.test", "7"}
|
||||||
set.Parse(test)
|
_ = set.Parse(test)
|
||||||
|
|
||||||
c := cli.NewContext(app, set, nil)
|
c := cli.NewContext(app, set, nil)
|
||||||
|
|
||||||
@ -187,7 +187,7 @@ func TestCommandJSONFileTestDefaultValueFileWins(t *testing.T) {
|
|||||||
app := cli.NewApp()
|
app := cli.NewApp()
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
test := []string{"test-cmd", "--load", fileName}
|
test := []string{"test-cmd", "--load", fileName}
|
||||||
set.Parse(test)
|
_ = set.Parse(test)
|
||||||
|
|
||||||
c := cli.NewContext(app, set, nil)
|
c := cli.NewContext(app, set, nil)
|
||||||
|
|
||||||
@ -219,7 +219,7 @@ func TestCommandJSONFileTestDefaultValueFileWinsNested(t *testing.T) {
|
|||||||
app := cli.NewApp()
|
app := cli.NewApp()
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
test := []string{"test-cmd", "--load", fileName}
|
test := []string{"test-cmd", "--load", fileName}
|
||||||
set.Parse(test)
|
_ = set.Parse(test)
|
||||||
|
|
||||||
c := cli.NewContext(app, set, nil)
|
c := cli.NewContext(app, set, nil)
|
||||||
|
|
||||||
@ -250,11 +250,11 @@ func TestCommandJSONFileFlagHasDefaultGlobalEnvJSONSetGlobalEnvWins(t *testing.T
|
|||||||
|
|
||||||
app := cli.NewApp()
|
app := cli.NewApp()
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
os.Setenv("THE_TEST", "11")
|
_ = os.Setenv("THE_TEST", "11")
|
||||||
defer os.Setenv("THE_TEST", "")
|
defer os.Setenv("THE_TEST", "")
|
||||||
|
|
||||||
test := []string{"test-cmd", "--load", fileName}
|
test := []string{"test-cmd", "--load", fileName}
|
||||||
set.Parse(test)
|
_ = set.Parse(test)
|
||||||
|
|
||||||
c := cli.NewContext(app, set, nil)
|
c := cli.NewContext(app, set, nil)
|
||||||
|
|
||||||
@ -284,11 +284,11 @@ func TestCommandJSONFileFlagHasDefaultGlobalEnvJSONSetGlobalEnvWinsNested(t *tes
|
|||||||
|
|
||||||
app := cli.NewApp()
|
app := cli.NewApp()
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
os.Setenv("THE_TEST", "11")
|
_ = os.Setenv("THE_TEST", "11")
|
||||||
defer os.Setenv("THE_TEST", "")
|
defer os.Setenv("THE_TEST", "")
|
||||||
|
|
||||||
test := []string{"test-cmd", "--load", fileName}
|
test := []string{"test-cmd", "--load", fileName}
|
||||||
set.Parse(test)
|
_ = set.Parse(test)
|
||||||
|
|
||||||
c := cli.NewContext(app, set, nil)
|
c := cli.NewContext(app, set, nil)
|
||||||
|
|
||||||
|
43
app.go
43
app.go
@ -11,9 +11,10 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
changeLogURL = "https://github.com/urfave/cli/blob/master/CHANGELOG.md"
|
changeLogURL = "https://github.com/urfave/cli/blob/master/CHANGELOG.md"
|
||||||
appActionDeprecationURL = fmt.Sprintf("%s#deprecated-cli-app-action-signature", changeLogURL)
|
appActionDeprecationURL = fmt.Sprintf("%s#deprecated-cli-app-action-signature", changeLogURL)
|
||||||
runAndExitOnErrorDeprecationURL = fmt.Sprintf("%s#deprecated-cli-app-runandexitonerror", changeLogURL)
|
// unused variable. commented for now. will remove in future if agreed upon by everyone
|
||||||
|
//runAndExitOnErrorDeprecationURL = fmt.Sprintf("%s#deprecated-cli-app-runandexitonerror", changeLogURL)
|
||||||
|
|
||||||
contactSysadmin = "This is an error in the application. Please contact the distributor of this application if this is not you."
|
contactSysadmin = "This is an error in the application. Please contact the distributor of this application if this is not you."
|
||||||
|
|
||||||
@ -142,7 +143,7 @@ func (a *App) Setup() {
|
|||||||
a.Authors = append(a.Authors, Author{Name: a.Author, Email: a.Email})
|
a.Authors = append(a.Authors, Author{Name: a.Author, Email: a.Email})
|
||||||
}
|
}
|
||||||
|
|
||||||
newCmds := []Command{}
|
var newCmds []Command
|
||||||
for _, c := range a.Commands {
|
for _, c := range a.Commands {
|
||||||
if c.HelpName == "" {
|
if c.HelpName == "" {
|
||||||
c.HelpName = fmt.Sprintf("%s %s", a.HelpName, c.Name)
|
c.HelpName = fmt.Sprintf("%s %s", a.HelpName, c.Name)
|
||||||
@ -207,8 +208,8 @@ func (a *App) Run(arguments []string) (err error) {
|
|||||||
nerr := normalizeFlags(a.Flags, set)
|
nerr := normalizeFlags(a.Flags, set)
|
||||||
context := NewContext(a, set, nil)
|
context := NewContext(a, set, nil)
|
||||||
if nerr != nil {
|
if nerr != nil {
|
||||||
fmt.Fprintln(a.Writer, nerr)
|
_, _ = fmt.Fprintln(a.Writer, nerr)
|
||||||
ShowAppHelp(context)
|
_ = ShowAppHelp(context)
|
||||||
return nerr
|
return nerr
|
||||||
}
|
}
|
||||||
context.shellComplete = shellComplete
|
context.shellComplete = shellComplete
|
||||||
@ -223,13 +224,13 @@ func (a *App) Run(arguments []string) (err error) {
|
|||||||
a.handleExitCoder(context, err)
|
a.handleExitCoder(context, err)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
fmt.Fprintf(a.Writer, "%s %s\n\n", "Incorrect Usage.", err.Error())
|
_, _ = fmt.Fprintf(a.Writer, "%s %s\n\n", "Incorrect Usage.", err.Error())
|
||||||
ShowAppHelp(context)
|
_ = ShowAppHelp(context)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if !a.HideHelp && checkHelp(context) {
|
if !a.HideHelp && checkHelp(context) {
|
||||||
ShowAppHelp(context)
|
_ = ShowAppHelp(context)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -240,7 +241,7 @@ func (a *App) Run(arguments []string) (err error) {
|
|||||||
|
|
||||||
cerr := checkRequiredFlags(a.Flags, context)
|
cerr := checkRequiredFlags(a.Flags, context)
|
||||||
if cerr != nil {
|
if cerr != nil {
|
||||||
ShowAppHelp(context)
|
_ = ShowAppHelp(context)
|
||||||
return cerr
|
return cerr
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -259,8 +260,8 @@ func (a *App) Run(arguments []string) (err error) {
|
|||||||
if a.Before != nil {
|
if a.Before != nil {
|
||||||
beforeErr := a.Before(context)
|
beforeErr := a.Before(context)
|
||||||
if beforeErr != nil {
|
if beforeErr != nil {
|
||||||
fmt.Fprintf(a.Writer, "%v\n\n", beforeErr)
|
_, _ = fmt.Fprintf(a.Writer, "%v\n\n", beforeErr)
|
||||||
ShowAppHelp(context)
|
_ = ShowAppHelp(context)
|
||||||
a.handleExitCoder(context, beforeErr)
|
a.handleExitCoder(context, beforeErr)
|
||||||
err = beforeErr
|
err = beforeErr
|
||||||
return err
|
return err
|
||||||
@ -294,7 +295,7 @@ func (a *App) Run(arguments []string) (err error) {
|
|||||||
// code in the cli.ExitCoder
|
// code in the cli.ExitCoder
|
||||||
func (a *App) RunAndExitOnError() {
|
func (a *App) RunAndExitOnError() {
|
||||||
if err := a.Run(os.Args); err != nil {
|
if err := a.Run(os.Args); err != nil {
|
||||||
fmt.Fprintln(a.errWriter(), err)
|
_, _ = fmt.Fprintln(a.errWriter(), err)
|
||||||
OsExiter(1)
|
OsExiter(1)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -331,12 +332,12 @@ func (a *App) RunAsSubcommand(ctx *Context) (err error) {
|
|||||||
context := NewContext(a, set, ctx)
|
context := NewContext(a, set, ctx)
|
||||||
|
|
||||||
if nerr != nil {
|
if nerr != nil {
|
||||||
fmt.Fprintln(a.Writer, nerr)
|
_, _ = fmt.Fprintln(a.Writer, nerr)
|
||||||
fmt.Fprintln(a.Writer)
|
_, _ = fmt.Fprintln(a.Writer)
|
||||||
if len(a.Commands) > 0 {
|
if len(a.Commands) > 0 {
|
||||||
ShowSubcommandHelp(context)
|
_ = ShowSubcommandHelp(context)
|
||||||
} else {
|
} else {
|
||||||
ShowCommandHelp(ctx, context.Args().First())
|
_ = ShowCommandHelp(ctx, context.Args().First())
|
||||||
}
|
}
|
||||||
return nerr
|
return nerr
|
||||||
}
|
}
|
||||||
@ -351,8 +352,8 @@ func (a *App) RunAsSubcommand(ctx *Context) (err error) {
|
|||||||
a.handleExitCoder(context, err)
|
a.handleExitCoder(context, err)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
fmt.Fprintf(a.Writer, "%s %s\n\n", "Incorrect Usage.", err.Error())
|
_, _ = fmt.Fprintf(a.Writer, "%s %s\n\n", "Incorrect Usage.", err.Error())
|
||||||
ShowSubcommandHelp(context)
|
_ = ShowSubcommandHelp(context)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -368,7 +369,7 @@ func (a *App) RunAsSubcommand(ctx *Context) (err error) {
|
|||||||
|
|
||||||
cerr := checkRequiredFlags(a.Flags, context)
|
cerr := checkRequiredFlags(a.Flags, context)
|
||||||
if cerr != nil {
|
if cerr != nil {
|
||||||
ShowSubcommandHelp(context)
|
_ = ShowSubcommandHelp(context)
|
||||||
return cerr
|
return cerr
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -448,7 +449,7 @@ func (a *App) VisibleCategories() []*CommandCategory {
|
|||||||
|
|
||||||
// VisibleCommands returns a slice of the Commands with Hidden=false
|
// VisibleCommands returns a slice of the Commands with Hidden=false
|
||||||
func (a *App) VisibleCommands() []Command {
|
func (a *App) VisibleCommands() []Command {
|
||||||
ret := []Command{}
|
var ret []Command
|
||||||
for _, command := range a.Commands {
|
for _, command := range a.Commands {
|
||||||
if !command.Hidden {
|
if !command.Hidden {
|
||||||
ret = append(ret, command)
|
ret = append(ret, command)
|
||||||
|
66
app_test.go
66
app_test.go
@ -47,7 +47,7 @@ func ExampleApp_Run() {
|
|||||||
app.Author = "Harrison"
|
app.Author = "Harrison"
|
||||||
app.Email = "harrison@lolwut.com"
|
app.Email = "harrison@lolwut.com"
|
||||||
app.Authors = []Author{{Name: "Oliver Allen", Email: "oliver@toyshop.com"}}
|
app.Authors = []Author{{Name: "Oliver Allen", Email: "oliver@toyshop.com"}}
|
||||||
app.Run(os.Args)
|
_ = app.Run(os.Args)
|
||||||
// Output:
|
// Output:
|
||||||
// Hello Jeremy
|
// Hello Jeremy
|
||||||
}
|
}
|
||||||
@ -85,7 +85,7 @@ func ExampleApp_Run_subcommand() {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
app.Run(os.Args)
|
_ = app.Run(os.Args)
|
||||||
// Output:
|
// Output:
|
||||||
// Hello, Jeremy
|
// Hello, Jeremy
|
||||||
}
|
}
|
||||||
@ -117,7 +117,7 @@ func ExampleApp_Run_appHelp() {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
app.Run(os.Args)
|
_ = app.Run(os.Args)
|
||||||
// Output:
|
// Output:
|
||||||
// NAME:
|
// NAME:
|
||||||
// greet - A new cli application
|
// greet - A new cli application
|
||||||
@ -166,7 +166,7 @@ func ExampleApp_Run_commandHelp() {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
app.Run(os.Args)
|
_ = app.Run(os.Args)
|
||||||
// Output:
|
// Output:
|
||||||
// NAME:
|
// NAME:
|
||||||
// greet describeit - use it to see a description
|
// greet describeit - use it to see a description
|
||||||
@ -181,7 +181,7 @@ func ExampleApp_Run_commandHelp() {
|
|||||||
func ExampleApp_Run_noAction() {
|
func ExampleApp_Run_noAction() {
|
||||||
app := App{}
|
app := App{}
|
||||||
app.Name = "greet"
|
app.Name = "greet"
|
||||||
app.Run([]string{"greet"})
|
_ = app.Run([]string{"greet"})
|
||||||
// Output:
|
// Output:
|
||||||
// NAME:
|
// NAME:
|
||||||
// greet
|
// greet
|
||||||
@ -208,7 +208,7 @@ func ExampleApp_Run_subcommandNoAction() {
|
|||||||
Description: "This is how we describe describeit the function",
|
Description: "This is how we describe describeit the function",
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
app.Run([]string{"greet", "describeit"})
|
_ = app.Run([]string{"greet", "describeit"})
|
||||||
// Output:
|
// Output:
|
||||||
// NAME:
|
// NAME:
|
||||||
// describeit - use it to see a description
|
// describeit - use it to see a description
|
||||||
@ -236,7 +236,7 @@ func ExampleApp_Run_bashComplete_withShortFlag() {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
app.Run(os.Args)
|
_ = app.Run(os.Args)
|
||||||
// Output:
|
// Output:
|
||||||
// --other
|
// --other
|
||||||
// -o
|
// -o
|
||||||
@ -269,7 +269,7 @@ func ExampleApp_Run_bashComplete_withLongFlag() {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
app.Run(os.Args)
|
_ = app.Run(os.Args)
|
||||||
// Output:
|
// Output:
|
||||||
// --some-flag
|
// --some-flag
|
||||||
// --similar-flag
|
// --similar-flag
|
||||||
@ -298,7 +298,7 @@ func ExampleApp_Run_bashComplete_withMultipleLongFlag() {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
app.Run(os.Args)
|
_ = app.Run(os.Args)
|
||||||
// Output:
|
// Output:
|
||||||
// --string
|
// --string
|
||||||
// --string-flag-2
|
// --string-flag-2
|
||||||
@ -332,7 +332,7 @@ func ExampleApp_Run_bashComplete() {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
app.Run(os.Args)
|
_ = app.Run(os.Args)
|
||||||
// Output:
|
// Output:
|
||||||
// describeit
|
// describeit
|
||||||
// d
|
// d
|
||||||
@ -344,7 +344,7 @@ func ExampleApp_Run_bashComplete() {
|
|||||||
func ExampleApp_Run_zshComplete() {
|
func ExampleApp_Run_zshComplete() {
|
||||||
// set args for examples sake
|
// set args for examples sake
|
||||||
os.Args = []string{"greet", "--generate-bash-completion"}
|
os.Args = []string{"greet", "--generate-bash-completion"}
|
||||||
os.Setenv("_CLI_ZSH_AUTOCOMPLETE_HACK", "1")
|
_ = os.Setenv("_CLI_ZSH_AUTOCOMPLETE_HACK", "1")
|
||||||
|
|
||||||
app := NewApp()
|
app := NewApp()
|
||||||
app.Name = "greet"
|
app.Name = "greet"
|
||||||
@ -370,7 +370,7 @@ func ExampleApp_Run_zshComplete() {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
app.Run(os.Args)
|
_ = app.Run(os.Args)
|
||||||
// Output:
|
// Output:
|
||||||
// describeit:use it to see a description
|
// describeit:use it to see a description
|
||||||
// d:use it to see a description
|
// d:use it to see a description
|
||||||
@ -444,7 +444,7 @@ func TestApp_CommandWithArgBeforeFlags(t *testing.T) {
|
|||||||
}
|
}
|
||||||
app.Commands = []Command{command}
|
app.Commands = []Command{command}
|
||||||
|
|
||||||
app.Run([]string{"", "cmd", "my-arg", "--option", "my-option"})
|
_ = app.Run([]string{"", "cmd", "my-arg", "--option", "my-option"})
|
||||||
|
|
||||||
expect(t, parsedOption, "my-option")
|
expect(t, parsedOption, "my-option")
|
||||||
expect(t, firstArg, "my-arg")
|
expect(t, firstArg, "my-arg")
|
||||||
@ -474,7 +474,7 @@ func TestApp_CommandWithArgBeforeBoolFlags(t *testing.T) {
|
|||||||
}
|
}
|
||||||
app.Commands = []Command{command}
|
app.Commands = []Command{command}
|
||||||
|
|
||||||
app.Run([]string{"", "cmd", "my-arg", "--boolflag", "--option", "my-option", "-b", "--secondOption", "fancy-option"})
|
_ = app.Run([]string{"", "cmd", "my-arg", "--boolflag", "--option", "my-option", "-b", "--secondOption", "fancy-option"})
|
||||||
|
|
||||||
expect(t, parsedOption, "my-option")
|
expect(t, parsedOption, "my-option")
|
||||||
expect(t, parsedSecondOption, "fancy-option")
|
expect(t, parsedSecondOption, "fancy-option")
|
||||||
@ -504,7 +504,7 @@ func TestApp_RunAsSubcommandParseFlags(t *testing.T) {
|
|||||||
Before: func(_ *Context) error { return nil },
|
Before: func(_ *Context) error { return nil },
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
a.Run([]string{"", "foo", "--lang", "spanish", "abcd"})
|
_ = a.Run([]string{"", "foo", "--lang", "spanish", "abcd"})
|
||||||
|
|
||||||
expect(t, context.Args().Get(0), "abcd")
|
expect(t, context.Args().Get(0), "abcd")
|
||||||
expect(t, context.String("lang"), "spanish")
|
expect(t, context.String("lang"), "spanish")
|
||||||
@ -519,7 +519,7 @@ func TestApp_RunAsSubCommandIncorrectUsage(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
set := flag.NewFlagSet("", flag.ContinueOnError)
|
set := flag.NewFlagSet("", flag.ContinueOnError)
|
||||||
set.Parse([]string{"", "---foo"})
|
_ = set.Parse([]string{"", "---foo"})
|
||||||
c := &Context{flagSet: set}
|
c := &Context{flagSet: set}
|
||||||
|
|
||||||
err := a.RunAsSubcommand(c)
|
err := a.RunAsSubcommand(c)
|
||||||
@ -545,7 +545,7 @@ func TestApp_CommandWithFlagBeforeTerminator(t *testing.T) {
|
|||||||
}
|
}
|
||||||
app.Commands = []Command{command}
|
app.Commands = []Command{command}
|
||||||
|
|
||||||
app.Run([]string{"", "cmd", "my-arg", "--option", "my-option", "--", "--notARealFlag"})
|
_ = app.Run([]string{"", "cmd", "my-arg", "--option", "my-option", "--", "--notARealFlag"})
|
||||||
|
|
||||||
expect(t, parsedOption, "my-option")
|
expect(t, parsedOption, "my-option")
|
||||||
expect(t, args[0], "my-arg")
|
expect(t, args[0], "my-arg")
|
||||||
@ -566,7 +566,7 @@ func TestApp_CommandWithDash(t *testing.T) {
|
|||||||
}
|
}
|
||||||
app.Commands = []Command{command}
|
app.Commands = []Command{command}
|
||||||
|
|
||||||
app.Run([]string{"", "cmd", "my-arg", "-"})
|
_ = app.Run([]string{"", "cmd", "my-arg", "-"})
|
||||||
|
|
||||||
expect(t, args[0], "my-arg")
|
expect(t, args[0], "my-arg")
|
||||||
expect(t, args[1], "-")
|
expect(t, args[1], "-")
|
||||||
@ -585,7 +585,7 @@ func TestApp_CommandWithNoFlagBeforeTerminator(t *testing.T) {
|
|||||||
}
|
}
|
||||||
app.Commands = []Command{command}
|
app.Commands = []Command{command}
|
||||||
|
|
||||||
app.Run([]string{"", "cmd", "my-arg", "--", "notAFlagAtAll"})
|
_ = app.Run([]string{"", "cmd", "my-arg", "--", "notAFlagAtAll"})
|
||||||
|
|
||||||
expect(t, args[0], "my-arg")
|
expect(t, args[0], "my-arg")
|
||||||
expect(t, args[1], "--")
|
expect(t, args[1], "--")
|
||||||
@ -734,7 +734,7 @@ func TestApp_Float64Flag(t *testing.T) {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
app.Run([]string{"", "--height", "1.93"})
|
_ = app.Run([]string{"", "--height", "1.93"})
|
||||||
expect(t, meters, 1.93)
|
expect(t, meters, 1.93)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -757,7 +757,7 @@ func TestApp_ParseSliceFlags(t *testing.T) {
|
|||||||
}
|
}
|
||||||
app.Commands = []Command{command}
|
app.Commands = []Command{command}
|
||||||
|
|
||||||
app.Run([]string{"", "cmd", "my-arg", "-p", "22", "-p", "80", "-ip", "8.8.8.8", "-ip", "8.8.4.4"})
|
_ = app.Run([]string{"", "cmd", "my-arg", "-p", "22", "-p", "80", "-ip", "8.8.8.8", "-ip", "8.8.4.4"})
|
||||||
|
|
||||||
IntsEquals := func(a, b []int) bool {
|
IntsEquals := func(a, b []int) bool {
|
||||||
if len(a) != len(b) {
|
if len(a) != len(b) {
|
||||||
@ -813,7 +813,7 @@ func TestApp_ParseSliceFlagsWithMissingValue(t *testing.T) {
|
|||||||
}
|
}
|
||||||
app.Commands = []Command{command}
|
app.Commands = []Command{command}
|
||||||
|
|
||||||
app.Run([]string{"", "cmd", "my-arg", "-a", "2", "-str", "A"})
|
_ = app.Run([]string{"", "cmd", "my-arg", "-a", "2", "-str", "A"})
|
||||||
|
|
||||||
var expectedIntSlice = []int{2}
|
var expectedIntSlice = []int{2}
|
||||||
var expectedStringSlice = []string{"A"}
|
var expectedStringSlice = []string{"A"}
|
||||||
@ -1199,7 +1199,7 @@ func TestAppHelpPrinter(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
app := NewApp()
|
app := NewApp()
|
||||||
app.Run([]string{"-h"})
|
_ = app.Run([]string{"-h"})
|
||||||
|
|
||||||
if wasCalled == false {
|
if wasCalled == false {
|
||||||
t.Errorf("Help printer expected to be called, but was not")
|
t.Errorf("Help printer expected to be called, but was not")
|
||||||
@ -1246,7 +1246,7 @@ func TestApp_CommandNotFound(t *testing.T) {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
app.Run([]string{"command", "foo"})
|
_ = app.Run([]string{"command", "foo"})
|
||||||
|
|
||||||
expect(t, counts.CommandNotFound, 1)
|
expect(t, counts.CommandNotFound, 1)
|
||||||
expect(t, counts.SubCommand, 0)
|
expect(t, counts.SubCommand, 0)
|
||||||
@ -1656,7 +1656,7 @@ func TestApp_Run_Categories(t *testing.T) {
|
|||||||
buf := new(bytes.Buffer)
|
buf := new(bytes.Buffer)
|
||||||
app.Writer = buf
|
app.Writer = buf
|
||||||
|
|
||||||
app.Run([]string{"categories"})
|
_ = app.Run([]string{"categories"})
|
||||||
|
|
||||||
expect := CommandCategories{
|
expect := CommandCategories{
|
||||||
&CommandCategory{
|
&CommandCategory{
|
||||||
@ -2075,7 +2075,7 @@ func TestHandleExitCoder_Custom(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
app.ExitErrHandler = func(_ *Context, _ error) {
|
app.ExitErrHandler = func(_ *Context, _ error) {
|
||||||
fmt.Fprintln(ErrWriter, "I'm a Custom error handler, I print what I want!")
|
_, _ = fmt.Fprintln(ErrWriter, "I'm a Custom error handler, I print what I want!")
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx := NewContext(app, fs, nil)
|
ctx := NewContext(app, fs, nil)
|
||||||
@ -2094,14 +2094,14 @@ func TestHandleAction_WithUnknownPanic(t *testing.T) {
|
|||||||
|
|
||||||
app := NewApp()
|
app := NewApp()
|
||||||
app.Action = func(ctx *Context) error {
|
app.Action = func(ctx *Context) error {
|
||||||
fn(ctx)
|
_ = fn(ctx)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
fs, err := flagSet(app.Name, app.Flags)
|
fs, err := flagSet(app.Name, app.Flags)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Errorf("error creating FlagSet: %s", err)
|
t.Errorf("error creating FlagSet: %s", err)
|
||||||
}
|
}
|
||||||
HandleAction(app.Action, NewContext(app, fs, nil))
|
_ = HandleAction(app.Action, NewContext(app, fs, nil))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestShellCompletionForIncompleteFlags(t *testing.T) {
|
func TestShellCompletionForIncompleteFlags(t *testing.T) {
|
||||||
@ -2119,12 +2119,12 @@ func TestShellCompletionForIncompleteFlags(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for _, name := range command.Names() {
|
for _, name := range command.Names() {
|
||||||
fmt.Fprintln(ctx.App.Writer, name)
|
_, _ = fmt.Fprintln(ctx.App.Writer, name)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, flag := range ctx.App.Flags {
|
for _, f := range ctx.App.Flags {
|
||||||
for _, name := range strings.Split(flag.GetName(), ",") {
|
for _, name := range strings.Split(f.GetName(), ",") {
|
||||||
if name == BashCompletionFlag.GetName() {
|
if name == BashCompletionFlag.GetName() {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
@ -2132,9 +2132,9 @@ func TestShellCompletionForIncompleteFlags(t *testing.T) {
|
|||||||
switch name = strings.TrimSpace(name); len(name) {
|
switch name = strings.TrimSpace(name); len(name) {
|
||||||
case 0:
|
case 0:
|
||||||
case 1:
|
case 1:
|
||||||
fmt.Fprintln(ctx.App.Writer, "-"+name)
|
_, _ = fmt.Fprintln(ctx.App.Writer, "-"+name)
|
||||||
default:
|
default:
|
||||||
fmt.Fprintln(ctx.App.Writer, "--"+name)
|
_, _ = fmt.Fprintln(ctx.App.Writer, "--"+name)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
10
command.go
10
command.go
@ -128,9 +128,9 @@ func (c Command) Run(ctx *Context) (err error) {
|
|||||||
context.App.handleExitCoder(context, err)
|
context.App.handleExitCoder(context, err)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
fmt.Fprintln(context.App.Writer, "Incorrect Usage:", err.Error())
|
_, _ = fmt.Fprintln(context.App.Writer, "Incorrect Usage:", err.Error())
|
||||||
fmt.Fprintln(context.App.Writer)
|
_, _ = fmt.Fprintln(context.App.Writer)
|
||||||
ShowCommandHelp(context, c.Name)
|
_ = ShowCommandHelp(context, c.Name)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -140,7 +140,7 @@ func (c Command) Run(ctx *Context) (err error) {
|
|||||||
|
|
||||||
cerr := checkRequiredFlags(c.Flags, context)
|
cerr := checkRequiredFlags(c.Flags, context)
|
||||||
if cerr != nil {
|
if cerr != nil {
|
||||||
ShowCommandHelp(context, c.Name)
|
_ = ShowCommandHelp(context, c.Name)
|
||||||
return cerr
|
return cerr
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -161,7 +161,7 @@ func (c Command) Run(ctx *Context) (err error) {
|
|||||||
if c.Before != nil {
|
if c.Before != nil {
|
||||||
err = c.Before(context)
|
err = c.Before(context)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ShowCommandHelp(context, c.Name)
|
_ = ShowCommandHelp(context, c.Name)
|
||||||
context.App.handleExitCoder(context, err)
|
context.App.handleExitCoder(context, err)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -35,7 +35,7 @@ func TestCommandFlagParsing(t *testing.T) {
|
|||||||
app := NewApp()
|
app := NewApp()
|
||||||
app.Writer = ioutil.Discard
|
app.Writer = ioutil.Discard
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
set.Parse(c.testArgs)
|
_ = set.Parse(c.testArgs)
|
||||||
|
|
||||||
context := NewContext(app, set, nil)
|
context := NewContext(app, set, nil)
|
||||||
|
|
||||||
@ -59,9 +59,9 @@ func TestCommandFlagParsing(t *testing.T) {
|
|||||||
|
|
||||||
func TestParseAndRunShortOpts(t *testing.T) {
|
func TestParseAndRunShortOpts(t *testing.T) {
|
||||||
cases := []struct {
|
cases := []struct {
|
||||||
testArgs []string
|
testArgs []string
|
||||||
expectedErr error
|
expectedErr error
|
||||||
expectedArgs []string
|
expectedArgs []string
|
||||||
}{
|
}{
|
||||||
{[]string{"foo", "test", "-a"}, nil, []string{}},
|
{[]string{"foo", "test", "-a"}, nil, []string{}},
|
||||||
{[]string{"foo", "test", "-c", "arg1", "arg2"}, nil, []string{"arg1", "arg2"}},
|
{[]string{"foo", "test", "-c", "arg1", "arg2"}, nil, []string{"arg1", "arg2"}},
|
||||||
@ -71,18 +71,18 @@ func TestParseAndRunShortOpts(t *testing.T) {
|
|||||||
{[]string{"foo", "test", "-cf"}, nil, []string{}},
|
{[]string{"foo", "test", "-cf"}, nil, []string{}},
|
||||||
{[]string{"foo", "test", "-acf"}, nil, []string{}},
|
{[]string{"foo", "test", "-acf"}, nil, []string{}},
|
||||||
{[]string{"foo", "test", "-invalid"}, errors.New("flag provided but not defined: -invalid"), []string{}},
|
{[]string{"foo", "test", "-invalid"}, errors.New("flag provided but not defined: -invalid"), []string{}},
|
||||||
{[]string{"foo", "test", "-acf", "arg1", "-invalid"}, nil, []string{"arg1" ,"-invalid"}},
|
{[]string{"foo", "test", "-acf", "arg1", "-invalid"}, nil, []string{"arg1", "-invalid"}},
|
||||||
}
|
}
|
||||||
|
|
||||||
var args []string
|
var args []string
|
||||||
cmd := Command{
|
cmd := Command{
|
||||||
Name: "test",
|
Name: "test",
|
||||||
Usage: "this is for testing",
|
Usage: "this is for testing",
|
||||||
Description: "testing",
|
Description: "testing",
|
||||||
Action: func(c *Context) error {
|
Action: func(c *Context) error {
|
||||||
args = c.Args()
|
args = c.Args()
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
SkipArgReorder: true,
|
SkipArgReorder: true,
|
||||||
UseShortOptionHandling: true,
|
UseShortOptionHandling: true,
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
@ -304,7 +304,7 @@ func TestCommandFlagReordering(t *testing.T) {
|
|||||||
|
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
value := ""
|
value := ""
|
||||||
args := []string{}
|
var args []string
|
||||||
app := &App{
|
app := &App{
|
||||||
Commands: []Command{
|
Commands: []Command{
|
||||||
{
|
{
|
||||||
@ -339,7 +339,7 @@ func TestCommandSkipFlagParsing(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
args := []string{}
|
var args []string
|
||||||
app := &App{
|
app := &App{
|
||||||
Commands: []Command{
|
Commands: []Command{
|
||||||
{
|
{
|
||||||
|
10
context.go
10
context.go
@ -139,8 +139,8 @@ func (c *Context) GlobalIsSet(name string) bool {
|
|||||||
|
|
||||||
// FlagNames returns a slice of flag names used in this context.
|
// FlagNames returns a slice of flag names used in this context.
|
||||||
func (c *Context) FlagNames() (names []string) {
|
func (c *Context) FlagNames() (names []string) {
|
||||||
for _, flag := range c.Command.Flags {
|
for _, f := range c.Command.Flags {
|
||||||
name := strings.Split(flag.GetName(), ",")[0]
|
name := strings.Split(f.GetName(), ",")[0]
|
||||||
if name == "help" {
|
if name == "help" {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
@ -151,8 +151,8 @@ func (c *Context) FlagNames() (names []string) {
|
|||||||
|
|
||||||
// GlobalFlagNames returns a slice of global flag names used by the app.
|
// GlobalFlagNames returns a slice of global flag names used by the app.
|
||||||
func (c *Context) GlobalFlagNames() (names []string) {
|
func (c *Context) GlobalFlagNames() (names []string) {
|
||||||
for _, flag := range c.App.Flags {
|
for _, f := range c.App.Flags {
|
||||||
name := strings.Split(flag.GetName(), ",")[0]
|
name := strings.Split(f.GetName(), ",")[0]
|
||||||
if name == "help" || name == "version" {
|
if name == "help" || name == "version" {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
@ -250,7 +250,7 @@ func copyFlag(name string, ff *flag.Flag, set *flag.FlagSet) {
|
|||||||
switch ff.Value.(type) {
|
switch ff.Value.(type) {
|
||||||
case *StringSlice:
|
case *StringSlice:
|
||||||
default:
|
default:
|
||||||
set.Set(name, ff.Value.String())
|
_ = set.Set(name, ff.Value.String())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -99,9 +99,9 @@ func TestContext_GlobalFloat64(t *testing.T) {
|
|||||||
|
|
||||||
func TestContext_Duration(t *testing.T) {
|
func TestContext_Duration(t *testing.T) {
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
set.Duration("myflag", time.Duration(12*time.Second), "doc")
|
set.Duration("myflag", 12*time.Second, "doc")
|
||||||
c := NewContext(nil, set, nil)
|
c := NewContext(nil, set, nil)
|
||||||
expect(t, c.Duration("myflag"), time.Duration(12*time.Second))
|
expect(t, c.Duration("myflag"), 12*time.Second)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestContext_String(t *testing.T) {
|
func TestContext_String(t *testing.T) {
|
||||||
@ -153,7 +153,7 @@ func TestContext_Args(t *testing.T) {
|
|||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
set.Bool("myflag", false, "doc")
|
set.Bool("myflag", false, "doc")
|
||||||
c := NewContext(nil, set, nil)
|
c := NewContext(nil, set, nil)
|
||||||
set.Parse([]string{"--myflag", "bat", "baz"})
|
_ = set.Parse([]string{"--myflag", "bat", "baz"})
|
||||||
expect(t, len(c.Args()), 2)
|
expect(t, len(c.Args()), 2)
|
||||||
expect(t, c.Bool("myflag"), true)
|
expect(t, c.Bool("myflag"), true)
|
||||||
}
|
}
|
||||||
@ -162,7 +162,7 @@ func TestContext_NArg(t *testing.T) {
|
|||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
set.Bool("myflag", false, "doc")
|
set.Bool("myflag", false, "doc")
|
||||||
c := NewContext(nil, set, nil)
|
c := NewContext(nil, set, nil)
|
||||||
set.Parse([]string{"--myflag", "bat", "baz"})
|
_ = set.Parse([]string{"--myflag", "bat", "baz"})
|
||||||
expect(t, c.NArg(), 2)
|
expect(t, c.NArg(), 2)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -174,8 +174,8 @@ func TestContext_IsSet(t *testing.T) {
|
|||||||
globalSet.Bool("myflagGlobal", true, "doc")
|
globalSet.Bool("myflagGlobal", true, "doc")
|
||||||
globalCtx := NewContext(nil, globalSet, nil)
|
globalCtx := NewContext(nil, globalSet, nil)
|
||||||
c := NewContext(nil, set, globalCtx)
|
c := NewContext(nil, set, globalCtx)
|
||||||
set.Parse([]string{"--myflag", "bat", "baz"})
|
_ = set.Parse([]string{"--myflag", "bat", "baz"})
|
||||||
globalSet.Parse([]string{"--myflagGlobal", "bat", "baz"})
|
_ = globalSet.Parse([]string{"--myflagGlobal", "bat", "baz"})
|
||||||
expect(t, c.IsSet("myflag"), true)
|
expect(t, c.IsSet("myflag"), true)
|
||||||
expect(t, c.IsSet("otherflag"), false)
|
expect(t, c.IsSet("otherflag"), false)
|
||||||
expect(t, c.IsSet("bogusflag"), false)
|
expect(t, c.IsSet("bogusflag"), false)
|
||||||
@ -193,8 +193,8 @@ func TestContext_IsSet_fromEnv(t *testing.T) {
|
|||||||
)
|
)
|
||||||
|
|
||||||
clearenv()
|
clearenv()
|
||||||
os.Setenv("APP_TIMEOUT_SECONDS", "15.5")
|
_ = os.Setenv("APP_TIMEOUT_SECONDS", "15.5")
|
||||||
os.Setenv("APP_PASSWORD", "")
|
_ = os.Setenv("APP_PASSWORD", "")
|
||||||
a := App{
|
a := App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
Float64Flag{Name: "timeout, t", EnvVar: "APP_TIMEOUT_SECONDS"},
|
Float64Flag{Name: "timeout, t", EnvVar: "APP_TIMEOUT_SECONDS"},
|
||||||
@ -214,7 +214,7 @@ func TestContext_IsSet_fromEnv(t *testing.T) {
|
|||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
a.Run([]string{"run"})
|
_ = a.Run([]string{"run"})
|
||||||
expect(t, timeoutIsSet, true)
|
expect(t, timeoutIsSet, true)
|
||||||
expect(t, tIsSet, true)
|
expect(t, tIsSet, true)
|
||||||
expect(t, passwordIsSet, true)
|
expect(t, passwordIsSet, true)
|
||||||
@ -222,8 +222,8 @@ func TestContext_IsSet_fromEnv(t *testing.T) {
|
|||||||
expect(t, noEnvVarIsSet, false)
|
expect(t, noEnvVarIsSet, false)
|
||||||
expect(t, nIsSet, false)
|
expect(t, nIsSet, false)
|
||||||
|
|
||||||
os.Setenv("APP_UNPARSABLE", "foobar")
|
_ = os.Setenv("APP_UNPARSABLE", "foobar")
|
||||||
a.Run([]string{"run"})
|
_ = a.Run([]string{"run"})
|
||||||
expect(t, unparsableIsSet, false)
|
expect(t, unparsableIsSet, false)
|
||||||
expect(t, uIsSet, false)
|
expect(t, uIsSet, false)
|
||||||
}
|
}
|
||||||
@ -237,8 +237,8 @@ func TestContext_GlobalIsSet(t *testing.T) {
|
|||||||
globalSet.Bool("myflagGlobalUnset", true, "doc")
|
globalSet.Bool("myflagGlobalUnset", true, "doc")
|
||||||
globalCtx := NewContext(nil, globalSet, nil)
|
globalCtx := NewContext(nil, globalSet, nil)
|
||||||
c := NewContext(nil, set, globalCtx)
|
c := NewContext(nil, set, globalCtx)
|
||||||
set.Parse([]string{"--myflag", "bat", "baz"})
|
_ = set.Parse([]string{"--myflag", "bat", "baz"})
|
||||||
globalSet.Parse([]string{"--myflagGlobal", "bat", "baz"})
|
_ = globalSet.Parse([]string{"--myflagGlobal", "bat", "baz"})
|
||||||
expect(t, c.GlobalIsSet("myflag"), false)
|
expect(t, c.GlobalIsSet("myflag"), false)
|
||||||
expect(t, c.GlobalIsSet("otherflag"), false)
|
expect(t, c.GlobalIsSet("otherflag"), false)
|
||||||
expect(t, c.GlobalIsSet("bogusflag"), false)
|
expect(t, c.GlobalIsSet("bogusflag"), false)
|
||||||
@ -261,9 +261,9 @@ func TestContext_GlobalIsSet_fromEnv(t *testing.T) {
|
|||||||
)
|
)
|
||||||
|
|
||||||
clearenv()
|
clearenv()
|
||||||
os.Setenv("APP_TIMEOUT_SECONDS", "15.5")
|
_ = os.Setenv("APP_TIMEOUT_SECONDS", "15.5")
|
||||||
os.Setenv("APP_PASSWORD", "badpass")
|
_ = os.Setenv("APP_PASSWORD", "badpass")
|
||||||
os.Setenv("APP_OVERRIDE", "overridden")
|
_ = os.Setenv("APP_OVERRIDE", "overridden")
|
||||||
a := App{
|
a := App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
Float64Flag{Name: "timeout, t", EnvVar: "APP_TIMEOUT_SECONDS"},
|
Float64Flag{Name: "timeout, t", EnvVar: "APP_TIMEOUT_SECONDS"},
|
||||||
@ -308,7 +308,7 @@ func TestContext_GlobalIsSet_fromEnv(t *testing.T) {
|
|||||||
expect(t, oIsSet, true)
|
expect(t, oIsSet, true)
|
||||||
expect(t, overrideValue, "overridden")
|
expect(t, overrideValue, "overridden")
|
||||||
|
|
||||||
os.Setenv("APP_UNPARSABLE", "foobar")
|
_ = os.Setenv("APP_UNPARSABLE", "foobar")
|
||||||
if err := a.Run([]string{"run"}); err != nil {
|
if err := a.Run([]string{"run"}); err != nil {
|
||||||
t.Logf("error running Run(): %+v", err)
|
t.Logf("error running Run(): %+v", err)
|
||||||
}
|
}
|
||||||
@ -324,8 +324,8 @@ func TestContext_NumFlags(t *testing.T) {
|
|||||||
globalSet.Bool("myflagGlobal", true, "doc")
|
globalSet.Bool("myflagGlobal", true, "doc")
|
||||||
globalCtx := NewContext(nil, globalSet, nil)
|
globalCtx := NewContext(nil, globalSet, nil)
|
||||||
c := NewContext(nil, set, globalCtx)
|
c := NewContext(nil, set, globalCtx)
|
||||||
set.Parse([]string{"--myflag", "--otherflag=foo"})
|
_ = set.Parse([]string{"--myflag", "--otherflag=foo"})
|
||||||
globalSet.Parse([]string{"--myflagGlobal"})
|
_ = globalSet.Parse([]string{"--myflagGlobal"})
|
||||||
expect(t, c.NumFlags(), 2)
|
expect(t, c.NumFlags(), 2)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -341,7 +341,7 @@ func TestContext_GlobalFlag(t *testing.T) {
|
|||||||
globalFlagSet = c.GlobalIsSet("global")
|
globalFlagSet = c.GlobalIsSet("global")
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
app.Run([]string{"command", "-g", "foo"})
|
_ = app.Run([]string{"command", "-g", "foo"})
|
||||||
expect(t, globalFlag, "foo")
|
expect(t, globalFlag, "foo")
|
||||||
expect(t, globalFlagSet, true)
|
expect(t, globalFlagSet, true)
|
||||||
|
|
||||||
@ -379,7 +379,7 @@ func TestContext_GlobalFlagsInSubcommands(t *testing.T) {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
app.Run([]string{"command", "-d", "foo", "-p", "bar"})
|
_ = app.Run([]string{"command", "-d", "foo", "-p", "bar"})
|
||||||
|
|
||||||
expect(t, subcommandRun, true)
|
expect(t, subcommandRun, true)
|
||||||
expect(t, parentFlag, true)
|
expect(t, parentFlag, true)
|
||||||
@ -391,7 +391,7 @@ func TestContext_Set(t *testing.T) {
|
|||||||
c := NewContext(nil, set, nil)
|
c := NewContext(nil, set, nil)
|
||||||
|
|
||||||
expect(t, c.IsSet("int"), false)
|
expect(t, c.IsSet("int"), false)
|
||||||
c.Set("int", "1")
|
_ = c.Set("int", "1")
|
||||||
expect(t, c.Int("int"), 1)
|
expect(t, c.Int("int"), 1)
|
||||||
expect(t, c.IsSet("int"), true)
|
expect(t, c.IsSet("int"), true)
|
||||||
}
|
}
|
||||||
@ -406,12 +406,12 @@ func TestContext_GlobalSet(t *testing.T) {
|
|||||||
pc := NewContext(nil, gSet, nil)
|
pc := NewContext(nil, gSet, nil)
|
||||||
c := NewContext(nil, set, pc)
|
c := NewContext(nil, set, pc)
|
||||||
|
|
||||||
c.Set("int", "1")
|
_ = c.Set("int", "1")
|
||||||
expect(t, c.Int("int"), 1)
|
expect(t, c.Int("int"), 1)
|
||||||
expect(t, c.GlobalInt("int"), 5)
|
expect(t, c.GlobalInt("int"), 5)
|
||||||
|
|
||||||
expect(t, c.GlobalIsSet("int"), false)
|
expect(t, c.GlobalIsSet("int"), false)
|
||||||
c.GlobalSet("int", "1")
|
_ = c.GlobalSet("int", "1")
|
||||||
expect(t, c.Int("int"), 1)
|
expect(t, c.Int("int"), 1)
|
||||||
expect(t, c.GlobalInt("int"), 1)
|
expect(t, c.GlobalInt("int"), 1)
|
||||||
expect(t, c.GlobalIsSet("int"), true)
|
expect(t, c.GlobalIsSet("int"), true)
|
||||||
@ -525,10 +525,10 @@ func TestCheckRequiredFlags(t *testing.T) {
|
|||||||
for _, flags := range test.flags {
|
for _, flags := range test.flags {
|
||||||
flags.Apply(set)
|
flags.Apply(set)
|
||||||
}
|
}
|
||||||
set.Parse(test.parseInput)
|
_ = set.Parse(test.parseInput)
|
||||||
if test.envVarInput[0] != "" {
|
if test.envVarInput[0] != "" {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv(test.envVarInput[0], test.envVarInput[1])
|
_ = os.Setenv(test.envVarInput[0], test.envVarInput[1])
|
||||||
}
|
}
|
||||||
ctx := &Context{}
|
ctx := &Context{}
|
||||||
context := NewContext(ctx.App, set, ctx)
|
context := NewContext(ctx.App, set, ctx)
|
||||||
|
44
flag.go
44
flag.go
@ -142,7 +142,7 @@ type Generic interface {
|
|||||||
// provided by the user for parsing by the flag
|
// provided by the user for parsing by the flag
|
||||||
// Ignores parsing errors
|
// Ignores parsing errors
|
||||||
func (f GenericFlag) Apply(set *flag.FlagSet) {
|
func (f GenericFlag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError takes the flagset and calls Set on the generic flag with the value
|
// ApplyWithError takes the flagset and calls Set on the generic flag with the value
|
||||||
@ -189,7 +189,7 @@ func (f *StringSlice) Get() interface{} {
|
|||||||
// Apply populates the flag given the flag set and environment
|
// Apply populates the flag given the flag set and environment
|
||||||
// Ignores errors
|
// Ignores errors
|
||||||
func (f StringSliceFlag) Apply(set *flag.FlagSet) {
|
func (f StringSliceFlag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError populates the flag given the flag set and environment
|
// ApplyWithError populates the flag given the flag set and environment
|
||||||
@ -250,7 +250,7 @@ func (f *IntSlice) Get() interface{} {
|
|||||||
// Apply populates the flag given the flag set and environment
|
// Apply populates the flag given the flag set and environment
|
||||||
// Ignores errors
|
// Ignores errors
|
||||||
func (f IntSliceFlag) Apply(set *flag.FlagSet) {
|
func (f IntSliceFlag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError populates the flag given the flag set and environment
|
// ApplyWithError populates the flag given the flag set and environment
|
||||||
@ -311,7 +311,7 @@ func (f *Int64Slice) Get() interface{} {
|
|||||||
// Apply populates the flag given the flag set and environment
|
// Apply populates the flag given the flag set and environment
|
||||||
// Ignores errors
|
// Ignores errors
|
||||||
func (f Int64SliceFlag) Apply(set *flag.FlagSet) {
|
func (f Int64SliceFlag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError populates the flag given the flag set and environment
|
// ApplyWithError populates the flag given the flag set and environment
|
||||||
@ -343,7 +343,7 @@ func (f Int64SliceFlag) ApplyWithError(set *flag.FlagSet) error {
|
|||||||
// Apply populates the flag given the flag set and environment
|
// Apply populates the flag given the flag set and environment
|
||||||
// Ignores errors
|
// Ignores errors
|
||||||
func (f BoolFlag) Apply(set *flag.FlagSet) {
|
func (f BoolFlag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError populates the flag given the flag set and environment
|
// ApplyWithError populates the flag given the flag set and environment
|
||||||
@ -375,7 +375,7 @@ func (f BoolFlag) ApplyWithError(set *flag.FlagSet) error {
|
|||||||
// Apply populates the flag given the flag set and environment
|
// Apply populates the flag given the flag set and environment
|
||||||
// Ignores errors
|
// Ignores errors
|
||||||
func (f BoolTFlag) Apply(set *flag.FlagSet) {
|
func (f BoolTFlag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError populates the flag given the flag set and environment
|
// ApplyWithError populates the flag given the flag set and environment
|
||||||
@ -408,7 +408,7 @@ func (f BoolTFlag) ApplyWithError(set *flag.FlagSet) error {
|
|||||||
// Apply populates the flag given the flag set and environment
|
// Apply populates the flag given the flag set and environment
|
||||||
// Ignores errors
|
// Ignores errors
|
||||||
func (f StringFlag) Apply(set *flag.FlagSet) {
|
func (f StringFlag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError populates the flag given the flag set and environment
|
// ApplyWithError populates the flag given the flag set and environment
|
||||||
@ -431,7 +431,7 @@ func (f StringFlag) ApplyWithError(set *flag.FlagSet) error {
|
|||||||
// Apply populates the flag given the flag set and environment
|
// Apply populates the flag given the flag set and environment
|
||||||
// Ignores errors
|
// Ignores errors
|
||||||
func (f IntFlag) Apply(set *flag.FlagSet) {
|
func (f IntFlag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError populates the flag given the flag set and environment
|
// ApplyWithError populates the flag given the flag set and environment
|
||||||
@ -458,7 +458,7 @@ func (f IntFlag) ApplyWithError(set *flag.FlagSet) error {
|
|||||||
// Apply populates the flag given the flag set and environment
|
// Apply populates the flag given the flag set and environment
|
||||||
// Ignores errors
|
// Ignores errors
|
||||||
func (f Int64Flag) Apply(set *flag.FlagSet) {
|
func (f Int64Flag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError populates the flag given the flag set and environment
|
// ApplyWithError populates the flag given the flag set and environment
|
||||||
@ -486,7 +486,7 @@ func (f Int64Flag) ApplyWithError(set *flag.FlagSet) error {
|
|||||||
// Apply populates the flag given the flag set and environment
|
// Apply populates the flag given the flag set and environment
|
||||||
// Ignores errors
|
// Ignores errors
|
||||||
func (f UintFlag) Apply(set *flag.FlagSet) {
|
func (f UintFlag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError populates the flag given the flag set and environment
|
// ApplyWithError populates the flag given the flag set and environment
|
||||||
@ -514,7 +514,7 @@ func (f UintFlag) ApplyWithError(set *flag.FlagSet) error {
|
|||||||
// Apply populates the flag given the flag set and environment
|
// Apply populates the flag given the flag set and environment
|
||||||
// Ignores errors
|
// Ignores errors
|
||||||
func (f Uint64Flag) Apply(set *flag.FlagSet) {
|
func (f Uint64Flag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError populates the flag given the flag set and environment
|
// ApplyWithError populates the flag given the flag set and environment
|
||||||
@ -525,7 +525,7 @@ func (f Uint64Flag) ApplyWithError(set *flag.FlagSet) error {
|
|||||||
return fmt.Errorf("could not parse %s as uint64 value for flag %s: %s", envVal, f.Name, err)
|
return fmt.Errorf("could not parse %s as uint64 value for flag %s: %s", envVal, f.Name, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
f.Value = uint64(envValInt)
|
f.Value = envValInt
|
||||||
}
|
}
|
||||||
|
|
||||||
eachName(f.Name, func(name string) {
|
eachName(f.Name, func(name string) {
|
||||||
@ -542,7 +542,7 @@ func (f Uint64Flag) ApplyWithError(set *flag.FlagSet) error {
|
|||||||
// Apply populates the flag given the flag set and environment
|
// Apply populates the flag given the flag set and environment
|
||||||
// Ignores errors
|
// Ignores errors
|
||||||
func (f DurationFlag) Apply(set *flag.FlagSet) {
|
func (f DurationFlag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError populates the flag given the flag set and environment
|
// ApplyWithError populates the flag given the flag set and environment
|
||||||
@ -570,7 +570,7 @@ func (f DurationFlag) ApplyWithError(set *flag.FlagSet) error {
|
|||||||
// Apply populates the flag given the flag set and environment
|
// Apply populates the flag given the flag set and environment
|
||||||
// Ignores errors
|
// Ignores errors
|
||||||
func (f Float64Flag) Apply(set *flag.FlagSet) {
|
func (f Float64Flag) Apply(set *flag.FlagSet) {
|
||||||
f.ApplyWithError(set)
|
_ = f.ApplyWithError(set)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyWithError populates the flag given the flag set and environment
|
// ApplyWithError populates the flag given the flag set and environment
|
||||||
@ -581,7 +581,7 @@ func (f Float64Flag) ApplyWithError(set *flag.FlagSet) error {
|
|||||||
return fmt.Errorf("could not parse %s as float64 value for flag %s: %s", envVal, f.Name, err)
|
return fmt.Errorf("could not parse %s as float64 value for flag %s: %s", envVal, f.Name, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
f.Value = float64(envValFloat)
|
f.Value = envValFloat
|
||||||
}
|
}
|
||||||
|
|
||||||
eachName(f.Name, func(name string) {
|
eachName(f.Name, func(name string) {
|
||||||
@ -596,11 +596,11 @@ func (f Float64Flag) ApplyWithError(set *flag.FlagSet) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func visibleFlags(fl []Flag) []Flag {
|
func visibleFlags(fl []Flag) []Flag {
|
||||||
visible := []Flag{}
|
var visible []Flag
|
||||||
for _, flag := range fl {
|
for _, f := range fl {
|
||||||
field := flagValue(flag).FieldByName("Hidden")
|
field := flagValue(f).FieldByName("Hidden")
|
||||||
if !field.IsValid() || !field.Bool() {
|
if !field.IsValid() || !field.Bool() {
|
||||||
visible = append(visible, flag)
|
visible = append(visible, f)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return visible
|
return visible
|
||||||
@ -745,7 +745,7 @@ func stringifyFlag(f Flag) string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func stringifyIntSliceFlag(f IntSliceFlag) string {
|
func stringifyIntSliceFlag(f IntSliceFlag) string {
|
||||||
defaultVals := []string{}
|
var defaultVals []string
|
||||||
if f.Value != nil && len(f.Value.Value()) > 0 {
|
if f.Value != nil && len(f.Value.Value()) > 0 {
|
||||||
for _, i := range f.Value.Value() {
|
for _, i := range f.Value.Value() {
|
||||||
defaultVals = append(defaultVals, strconv.Itoa(i))
|
defaultVals = append(defaultVals, strconv.Itoa(i))
|
||||||
@ -756,7 +756,7 @@ func stringifyIntSliceFlag(f IntSliceFlag) string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func stringifyInt64SliceFlag(f Int64SliceFlag) string {
|
func stringifyInt64SliceFlag(f Int64SliceFlag) string {
|
||||||
defaultVals := []string{}
|
var defaultVals []string
|
||||||
if f.Value != nil && len(f.Value.Value()) > 0 {
|
if f.Value != nil && len(f.Value.Value()) > 0 {
|
||||||
for _, i := range f.Value.Value() {
|
for _, i := range f.Value.Value() {
|
||||||
defaultVals = append(defaultVals, strconv.FormatInt(i, 10))
|
defaultVals = append(defaultVals, strconv.FormatInt(i, 10))
|
||||||
@ -767,7 +767,7 @@ func stringifyInt64SliceFlag(f Int64SliceFlag) string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func stringifyStringSliceFlag(f StringSliceFlag) string {
|
func stringifyStringSliceFlag(f StringSliceFlag) string {
|
||||||
defaultVals := []string{}
|
var defaultVals []string
|
||||||
if f.Value != nil && len(f.Value.Value()) > 0 {
|
if f.Value != nil && len(f.Value.Value()) > 0 {
|
||||||
for _, s := range f.Value.Value() {
|
for _, s := range f.Value.Value() {
|
||||||
if len(s) > 0 {
|
if len(s) > 0 {
|
||||||
|
220
flag_test.go
220
flag_test.go
@ -89,7 +89,7 @@ func TestFlagsFromEnv(t *testing.T) {
|
|||||||
|
|
||||||
for _, test := range flagTests {
|
for _, test := range flagTests {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv(reflect.ValueOf(test.flag).FieldByName("EnvVar").String(), test.input)
|
_ = os.Setenv(reflect.ValueOf(test.flag).FieldByName("EnvVar").String(), test.input)
|
||||||
a := App{
|
a := App{
|
||||||
Flags: []Flag{test.flag},
|
Flags: []Flag{test.flag},
|
||||||
Action: func(ctx *Context) error {
|
Action: func(ctx *Context) error {
|
||||||
@ -145,7 +145,7 @@ func TestStringFlagHelpOutput(t *testing.T) {
|
|||||||
|
|
||||||
func TestStringFlagWithEnvVarHelpOutput(t *testing.T) {
|
func TestStringFlagWithEnvVarHelpOutput(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_FOO", "derp")
|
_ = os.Setenv("APP_FOO", "derp")
|
||||||
for _, test := range stringFlagTests {
|
for _, test := range stringFlagTests {
|
||||||
flag := StringFlag{Name: test.name, Value: test.value, EnvVar: "APP_FOO"}
|
flag := StringFlag{Name: test.name, Value: test.value, EnvVar: "APP_FOO"}
|
||||||
output := flag.String()
|
output := flag.String()
|
||||||
@ -244,22 +244,22 @@ var stringSliceFlagTests = []struct {
|
|||||||
}{
|
}{
|
||||||
{"foo", func() *StringSlice {
|
{"foo", func() *StringSlice {
|
||||||
s := &StringSlice{}
|
s := &StringSlice{}
|
||||||
s.Set("")
|
_ = s.Set("")
|
||||||
return s
|
return s
|
||||||
}(), "--foo value\t"},
|
}(), "--foo value\t"},
|
||||||
{"f", func() *StringSlice {
|
{"f", func() *StringSlice {
|
||||||
s := &StringSlice{}
|
s := &StringSlice{}
|
||||||
s.Set("")
|
_ = s.Set("")
|
||||||
return s
|
return s
|
||||||
}(), "-f value\t"},
|
}(), "-f value\t"},
|
||||||
{"f", func() *StringSlice {
|
{"f", func() *StringSlice {
|
||||||
s := &StringSlice{}
|
s := &StringSlice{}
|
||||||
s.Set("Lipstick")
|
_ = s.Set("Lipstick")
|
||||||
return s
|
return s
|
||||||
}(), "-f value\t(default: \"Lipstick\")"},
|
}(), "-f value\t(default: \"Lipstick\")"},
|
||||||
{"test", func() *StringSlice {
|
{"test", func() *StringSlice {
|
||||||
s := &StringSlice{}
|
s := &StringSlice{}
|
||||||
s.Set("Something")
|
_ = s.Set("Something")
|
||||||
return s
|
return s
|
||||||
}(), "--test value\t(default: \"Something\")"},
|
}(), "--test value\t(default: \"Something\")"},
|
||||||
}
|
}
|
||||||
@ -277,7 +277,7 @@ func TestStringSliceFlagHelpOutput(t *testing.T) {
|
|||||||
|
|
||||||
func TestStringSliceFlagWithEnvVarHelpOutput(t *testing.T) {
|
func TestStringSliceFlagWithEnvVarHelpOutput(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_QWWX", "11,4")
|
_ = os.Setenv("APP_QWWX", "11,4")
|
||||||
for _, test := range stringSliceFlagTests {
|
for _, test := range stringSliceFlagTests {
|
||||||
flag := StringSliceFlag{Name: test.name, Value: test.value, EnvVar: "APP_QWWX"}
|
flag := StringSliceFlag{Name: test.name, Value: test.value, EnvVar: "APP_QWWX"}
|
||||||
output := flag.String()
|
output := flag.String()
|
||||||
@ -313,7 +313,7 @@ func TestIntFlagHelpOutput(t *testing.T) {
|
|||||||
|
|
||||||
func TestIntFlagWithEnvVarHelpOutput(t *testing.T) {
|
func TestIntFlagWithEnvVarHelpOutput(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_BAR", "2")
|
_ = os.Setenv("APP_BAR", "2")
|
||||||
for _, test := range intFlagTests {
|
for _, test := range intFlagTests {
|
||||||
flag := IntFlag{Name: test.name, EnvVar: "APP_BAR"}
|
flag := IntFlag{Name: test.name, EnvVar: "APP_BAR"}
|
||||||
output := flag.String()
|
output := flag.String()
|
||||||
@ -349,7 +349,7 @@ func TestInt64FlagHelpOutput(t *testing.T) {
|
|||||||
|
|
||||||
func TestInt64FlagWithEnvVarHelpOutput(t *testing.T) {
|
func TestInt64FlagWithEnvVarHelpOutput(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_BAR", "2")
|
_ = os.Setenv("APP_BAR", "2")
|
||||||
for _, test := range int64FlagTests {
|
for _, test := range int64FlagTests {
|
||||||
flag := IntFlag{Name: test.name, EnvVar: "APP_BAR"}
|
flag := IntFlag{Name: test.name, EnvVar: "APP_BAR"}
|
||||||
output := flag.String()
|
output := flag.String()
|
||||||
@ -385,7 +385,7 @@ func TestUintFlagHelpOutput(t *testing.T) {
|
|||||||
|
|
||||||
func TestUintFlagWithEnvVarHelpOutput(t *testing.T) {
|
func TestUintFlagWithEnvVarHelpOutput(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_BAR", "2")
|
_ = os.Setenv("APP_BAR", "2")
|
||||||
for _, test := range uintFlagTests {
|
for _, test := range uintFlagTests {
|
||||||
flag := UintFlag{Name: test.name, EnvVar: "APP_BAR"}
|
flag := UintFlag{Name: test.name, EnvVar: "APP_BAR"}
|
||||||
output := flag.String()
|
output := flag.String()
|
||||||
@ -421,7 +421,7 @@ func TestUint64FlagHelpOutput(t *testing.T) {
|
|||||||
|
|
||||||
func TestUint64FlagWithEnvVarHelpOutput(t *testing.T) {
|
func TestUint64FlagWithEnvVarHelpOutput(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_BAR", "2")
|
_ = os.Setenv("APP_BAR", "2")
|
||||||
for _, test := range uint64FlagTests {
|
for _, test := range uint64FlagTests {
|
||||||
flag := UintFlag{Name: test.name, EnvVar: "APP_BAR"}
|
flag := UintFlag{Name: test.name, EnvVar: "APP_BAR"}
|
||||||
output := flag.String()
|
output := flag.String()
|
||||||
@ -457,7 +457,7 @@ func TestDurationFlagHelpOutput(t *testing.T) {
|
|||||||
|
|
||||||
func TestDurationFlagWithEnvVarHelpOutput(t *testing.T) {
|
func TestDurationFlagWithEnvVarHelpOutput(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_BAR", "2h3m6s")
|
_ = os.Setenv("APP_BAR", "2h3m6s")
|
||||||
for _, test := range durationFlagTests {
|
for _, test := range durationFlagTests {
|
||||||
flag := DurationFlag{Name: test.name, EnvVar: "APP_BAR"}
|
flag := DurationFlag{Name: test.name, EnvVar: "APP_BAR"}
|
||||||
output := flag.String()
|
output := flag.String()
|
||||||
@ -481,8 +481,8 @@ var intSliceFlagTests = []struct {
|
|||||||
{"H", &IntSlice{}, "-H value\t"},
|
{"H", &IntSlice{}, "-H value\t"},
|
||||||
{"H, heads", func() *IntSlice {
|
{"H, heads", func() *IntSlice {
|
||||||
i := &IntSlice{}
|
i := &IntSlice{}
|
||||||
i.Set("9")
|
_ = i.Set("9")
|
||||||
i.Set("3")
|
_ = i.Set("3")
|
||||||
return i
|
return i
|
||||||
}(), "-H value, --heads value\t(default: 9, 3)"},
|
}(), "-H value, --heads value\t(default: 9, 3)"},
|
||||||
}
|
}
|
||||||
@ -500,7 +500,7 @@ func TestIntSliceFlagHelpOutput(t *testing.T) {
|
|||||||
|
|
||||||
func TestIntSliceFlagWithEnvVarHelpOutput(t *testing.T) {
|
func TestIntSliceFlagWithEnvVarHelpOutput(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_SMURF", "42,3")
|
_ = os.Setenv("APP_SMURF", "42,3")
|
||||||
for _, test := range intSliceFlagTests {
|
for _, test := range intSliceFlagTests {
|
||||||
flag := IntSliceFlag{Name: test.name, Value: test.value, EnvVar: "APP_SMURF"}
|
flag := IntSliceFlag{Name: test.name, Value: test.value, EnvVar: "APP_SMURF"}
|
||||||
output := flag.String()
|
output := flag.String()
|
||||||
@ -524,8 +524,8 @@ var int64SliceFlagTests = []struct {
|
|||||||
{"H", &Int64Slice{}, "-H value\t"},
|
{"H", &Int64Slice{}, "-H value\t"},
|
||||||
{"H, heads", func() *Int64Slice {
|
{"H, heads", func() *Int64Slice {
|
||||||
i := &Int64Slice{}
|
i := &Int64Slice{}
|
||||||
i.Set("2")
|
_ = i.Set("2")
|
||||||
i.Set("17179869184")
|
_ = i.Set("17179869184")
|
||||||
return i
|
return i
|
||||||
}(), "-H value, --heads value\t(default: 2, 17179869184)"},
|
}(), "-H value, --heads value\t(default: 2, 17179869184)"},
|
||||||
}
|
}
|
||||||
@ -543,7 +543,7 @@ func TestInt64SliceFlagHelpOutput(t *testing.T) {
|
|||||||
|
|
||||||
func TestInt64SliceFlagWithEnvVarHelpOutput(t *testing.T) {
|
func TestInt64SliceFlagWithEnvVarHelpOutput(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_SMURF", "42,17179869184")
|
_ = os.Setenv("APP_SMURF", "42,17179869184")
|
||||||
for _, test := range int64SliceFlagTests {
|
for _, test := range int64SliceFlagTests {
|
||||||
flag := Int64SliceFlag{Name: test.name, Value: test.value, EnvVar: "APP_SMURF"}
|
flag := Int64SliceFlag{Name: test.name, Value: test.value, EnvVar: "APP_SMURF"}
|
||||||
output := flag.String()
|
output := flag.String()
|
||||||
@ -568,7 +568,7 @@ var float64FlagTests = []struct {
|
|||||||
|
|
||||||
func TestFloat64FlagHelpOutput(t *testing.T) {
|
func TestFloat64FlagHelpOutput(t *testing.T) {
|
||||||
for _, test := range float64FlagTests {
|
for _, test := range float64FlagTests {
|
||||||
flag := Float64Flag{Name: test.name, Value: float64(0.1)}
|
flag := Float64Flag{Name: test.name, Value: 0.1}
|
||||||
output := flag.String()
|
output := flag.String()
|
||||||
|
|
||||||
if output != test.expected {
|
if output != test.expected {
|
||||||
@ -579,7 +579,7 @@ func TestFloat64FlagHelpOutput(t *testing.T) {
|
|||||||
|
|
||||||
func TestFloat64FlagWithEnvVarHelpOutput(t *testing.T) {
|
func TestFloat64FlagWithEnvVarHelpOutput(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_BAZ", "99.4")
|
_ = os.Setenv("APP_BAZ", "99.4")
|
||||||
for _, test := range float64FlagTests {
|
for _, test := range float64FlagTests {
|
||||||
flag := Float64Flag{Name: test.name, EnvVar: "APP_BAZ"}
|
flag := Float64Flag{Name: test.name, EnvVar: "APP_BAZ"}
|
||||||
output := flag.String()
|
output := flag.String()
|
||||||
@ -616,7 +616,7 @@ func TestGenericFlagHelpOutput(t *testing.T) {
|
|||||||
|
|
||||||
func TestGenericFlagWithEnvVarHelpOutput(t *testing.T) {
|
func TestGenericFlagWithEnvVarHelpOutput(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_ZAP", "3")
|
_ = os.Setenv("APP_ZAP", "3")
|
||||||
for _, test := range genericFlagTests {
|
for _, test := range genericFlagTests {
|
||||||
flag := GenericFlag{Name: test.name, EnvVar: "APP_ZAP"}
|
flag := GenericFlag{Name: test.name, EnvVar: "APP_ZAP"}
|
||||||
output := flag.String()
|
output := flag.String()
|
||||||
@ -632,7 +632,7 @@ func TestGenericFlagWithEnvVarHelpOutput(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiString(t *testing.T) {
|
func TestParseMultiString(t *testing.T) {
|
||||||
(&App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
StringFlag{Name: "serve, s"},
|
StringFlag{Name: "serve, s"},
|
||||||
},
|
},
|
||||||
@ -650,7 +650,7 @@ func TestParseMultiString(t *testing.T) {
|
|||||||
|
|
||||||
func TestParseDestinationString(t *testing.T) {
|
func TestParseDestinationString(t *testing.T) {
|
||||||
var dest string
|
var dest string
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
StringFlag{
|
StringFlag{
|
||||||
Name: "dest",
|
Name: "dest",
|
||||||
@ -663,14 +663,13 @@ func TestParseDestinationString(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run", "--dest", "10"})
|
||||||
a.Run([]string{"run", "--dest", "10"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiStringFromEnv(t *testing.T) {
|
func TestParseMultiStringFromEnv(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_COUNT", "20")
|
_ = os.Setenv("APP_COUNT", "20")
|
||||||
(&App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
StringFlag{Name: "count, c", EnvVar: "APP_COUNT"},
|
StringFlag{Name: "count, c", EnvVar: "APP_COUNT"},
|
||||||
},
|
},
|
||||||
@ -688,8 +687,8 @@ func TestParseMultiStringFromEnv(t *testing.T) {
|
|||||||
|
|
||||||
func TestParseMultiStringFromEnvCascade(t *testing.T) {
|
func TestParseMultiStringFromEnvCascade(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_COUNT", "20")
|
_ = os.Setenv("APP_COUNT", "20")
|
||||||
(&App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
StringFlag{Name: "count, c", EnvVar: "COMPAT_COUNT,APP_COUNT"},
|
StringFlag{Name: "count, c", EnvVar: "COMPAT_COUNT,APP_COUNT"},
|
||||||
},
|
},
|
||||||
@ -706,7 +705,7 @@ func TestParseMultiStringFromEnvCascade(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiStringSlice(t *testing.T) {
|
func TestParseMultiStringSlice(t *testing.T) {
|
||||||
(&App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
StringSliceFlag{Name: "serve, s", Value: &StringSlice{}},
|
StringSliceFlag{Name: "serve, s", Value: &StringSlice{}},
|
||||||
},
|
},
|
||||||
@ -724,9 +723,9 @@ func TestParseMultiStringSlice(t *testing.T) {
|
|||||||
|
|
||||||
func TestParseMultiStringSliceFromEnv(t *testing.T) {
|
func TestParseMultiStringSliceFromEnv(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_INTERVALS", "20,30,40")
|
_ = os.Setenv("APP_INTERVALS", "20,30,40")
|
||||||
|
|
||||||
(&App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
StringSliceFlag{Name: "intervals, i", Value: &StringSlice{}, EnvVar: "APP_INTERVALS"},
|
StringSliceFlag{Name: "intervals, i", Value: &StringSlice{}, EnvVar: "APP_INTERVALS"},
|
||||||
},
|
},
|
||||||
@ -744,9 +743,9 @@ func TestParseMultiStringSliceFromEnv(t *testing.T) {
|
|||||||
|
|
||||||
func TestParseMultiStringSliceFromEnvCascade(t *testing.T) {
|
func TestParseMultiStringSliceFromEnvCascade(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_INTERVALS", "20,30,40")
|
_ = os.Setenv("APP_INTERVALS", "20,30,40")
|
||||||
|
|
||||||
(&App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
StringSliceFlag{Name: "intervals, i", Value: &StringSlice{}, EnvVar: "COMPAT_INTERVALS,APP_INTERVALS"},
|
StringSliceFlag{Name: "intervals, i", Value: &StringSlice{}, EnvVar: "COMPAT_INTERVALS,APP_INTERVALS"},
|
||||||
},
|
},
|
||||||
@ -763,7 +762,7 @@ func TestParseMultiStringSliceFromEnvCascade(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiInt(t *testing.T) {
|
func TestParseMultiInt(t *testing.T) {
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
IntFlag{Name: "serve, s"},
|
IntFlag{Name: "serve, s"},
|
||||||
},
|
},
|
||||||
@ -776,13 +775,12 @@ func TestParseMultiInt(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run", "-s", "10"})
|
||||||
a.Run([]string{"run", "-s", "10"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseDestinationInt(t *testing.T) {
|
func TestParseDestinationInt(t *testing.T) {
|
||||||
var dest int
|
var dest int
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
IntFlag{
|
IntFlag{
|
||||||
Name: "dest",
|
Name: "dest",
|
||||||
@ -795,14 +793,13 @@ func TestParseDestinationInt(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run", "--dest", "10"})
|
||||||
a.Run([]string{"run", "--dest", "10"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiIntFromEnv(t *testing.T) {
|
func TestParseMultiIntFromEnv(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_TIMEOUT_SECONDS", "10")
|
_ = os.Setenv("APP_TIMEOUT_SECONDS", "10")
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
IntFlag{Name: "timeout, t", EnvVar: "APP_TIMEOUT_SECONDS"},
|
IntFlag{Name: "timeout, t", EnvVar: "APP_TIMEOUT_SECONDS"},
|
||||||
},
|
},
|
||||||
@ -815,14 +812,13 @@ func TestParseMultiIntFromEnv(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run"})
|
||||||
a.Run([]string{"run"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiIntFromEnvCascade(t *testing.T) {
|
func TestParseMultiIntFromEnvCascade(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_TIMEOUT_SECONDS", "10")
|
_ = os.Setenv("APP_TIMEOUT_SECONDS", "10")
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
IntFlag{Name: "timeout, t", EnvVar: "COMPAT_TIMEOUT_SECONDS,APP_TIMEOUT_SECONDS"},
|
IntFlag{Name: "timeout, t", EnvVar: "COMPAT_TIMEOUT_SECONDS,APP_TIMEOUT_SECONDS"},
|
||||||
},
|
},
|
||||||
@ -835,12 +831,11 @@ func TestParseMultiIntFromEnvCascade(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run"})
|
||||||
a.Run([]string{"run"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiIntSlice(t *testing.T) {
|
func TestParseMultiIntSlice(t *testing.T) {
|
||||||
(&App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
IntSliceFlag{Name: "serve, s", Value: &IntSlice{}},
|
IntSliceFlag{Name: "serve, s", Value: &IntSlice{}},
|
||||||
},
|
},
|
||||||
@ -858,9 +853,9 @@ func TestParseMultiIntSlice(t *testing.T) {
|
|||||||
|
|
||||||
func TestParseMultiIntSliceFromEnv(t *testing.T) {
|
func TestParseMultiIntSliceFromEnv(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_INTERVALS", "20,30,40")
|
_ = os.Setenv("APP_INTERVALS", "20,30,40")
|
||||||
|
|
||||||
(&App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
IntSliceFlag{Name: "intervals, i", Value: &IntSlice{}, EnvVar: "APP_INTERVALS"},
|
IntSliceFlag{Name: "intervals, i", Value: &IntSlice{}, EnvVar: "APP_INTERVALS"},
|
||||||
},
|
},
|
||||||
@ -878,9 +873,9 @@ func TestParseMultiIntSliceFromEnv(t *testing.T) {
|
|||||||
|
|
||||||
func TestParseMultiIntSliceFromEnvCascade(t *testing.T) {
|
func TestParseMultiIntSliceFromEnvCascade(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_INTERVALS", "20,30,40")
|
_ = os.Setenv("APP_INTERVALS", "20,30,40")
|
||||||
|
|
||||||
(&App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
IntSliceFlag{Name: "intervals, i", Value: &IntSlice{}, EnvVar: "COMPAT_INTERVALS,APP_INTERVALS"},
|
IntSliceFlag{Name: "intervals, i", Value: &IntSlice{}, EnvVar: "COMPAT_INTERVALS,APP_INTERVALS"},
|
||||||
},
|
},
|
||||||
@ -897,7 +892,7 @@ func TestParseMultiIntSliceFromEnvCascade(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiInt64Slice(t *testing.T) {
|
func TestParseMultiInt64Slice(t *testing.T) {
|
||||||
(&App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
Int64SliceFlag{Name: "serve, s", Value: &Int64Slice{}},
|
Int64SliceFlag{Name: "serve, s", Value: &Int64Slice{}},
|
||||||
},
|
},
|
||||||
@ -915,9 +910,9 @@ func TestParseMultiInt64Slice(t *testing.T) {
|
|||||||
|
|
||||||
func TestParseMultiInt64SliceFromEnv(t *testing.T) {
|
func TestParseMultiInt64SliceFromEnv(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_INTERVALS", "20,30,17179869184")
|
_ = os.Setenv("APP_INTERVALS", "20,30,17179869184")
|
||||||
|
|
||||||
(&App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
Int64SliceFlag{Name: "intervals, i", Value: &Int64Slice{}, EnvVar: "APP_INTERVALS"},
|
Int64SliceFlag{Name: "intervals, i", Value: &Int64Slice{}, EnvVar: "APP_INTERVALS"},
|
||||||
},
|
},
|
||||||
@ -935,9 +930,9 @@ func TestParseMultiInt64SliceFromEnv(t *testing.T) {
|
|||||||
|
|
||||||
func TestParseMultiInt64SliceFromEnvCascade(t *testing.T) {
|
func TestParseMultiInt64SliceFromEnvCascade(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_INTERVALS", "20,30,17179869184")
|
_ = os.Setenv("APP_INTERVALS", "20,30,17179869184")
|
||||||
|
|
||||||
(&App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
Int64SliceFlag{Name: "intervals, i", Value: &Int64Slice{}, EnvVar: "COMPAT_INTERVALS,APP_INTERVALS"},
|
Int64SliceFlag{Name: "intervals, i", Value: &Int64Slice{}, EnvVar: "COMPAT_INTERVALS,APP_INTERVALS"},
|
||||||
},
|
},
|
||||||
@ -954,7 +949,7 @@ func TestParseMultiInt64SliceFromEnvCascade(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiFloat64(t *testing.T) {
|
func TestParseMultiFloat64(t *testing.T) {
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
Float64Flag{Name: "serve, s"},
|
Float64Flag{Name: "serve, s"},
|
||||||
},
|
},
|
||||||
@ -967,13 +962,12 @@ func TestParseMultiFloat64(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run", "-s", "10.2"})
|
||||||
a.Run([]string{"run", "-s", "10.2"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseDestinationFloat64(t *testing.T) {
|
func TestParseDestinationFloat64(t *testing.T) {
|
||||||
var dest float64
|
var dest float64
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
Float64Flag{
|
Float64Flag{
|
||||||
Name: "dest",
|
Name: "dest",
|
||||||
@ -986,14 +980,13 @@ func TestParseDestinationFloat64(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run", "--dest", "10.2"})
|
||||||
a.Run([]string{"run", "--dest", "10.2"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiFloat64FromEnv(t *testing.T) {
|
func TestParseMultiFloat64FromEnv(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_TIMEOUT_SECONDS", "15.5")
|
_ = os.Setenv("APP_TIMEOUT_SECONDS", "15.5")
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
Float64Flag{Name: "timeout, t", EnvVar: "APP_TIMEOUT_SECONDS"},
|
Float64Flag{Name: "timeout, t", EnvVar: "APP_TIMEOUT_SECONDS"},
|
||||||
},
|
},
|
||||||
@ -1006,14 +999,13 @@ func TestParseMultiFloat64FromEnv(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run"})
|
||||||
a.Run([]string{"run"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiFloat64FromEnvCascade(t *testing.T) {
|
func TestParseMultiFloat64FromEnvCascade(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_TIMEOUT_SECONDS", "15.5")
|
_ = os.Setenv("APP_TIMEOUT_SECONDS", "15.5")
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
Float64Flag{Name: "timeout, t", EnvVar: "COMPAT_TIMEOUT_SECONDS,APP_TIMEOUT_SECONDS"},
|
Float64Flag{Name: "timeout, t", EnvVar: "COMPAT_TIMEOUT_SECONDS,APP_TIMEOUT_SECONDS"},
|
||||||
},
|
},
|
||||||
@ -1026,12 +1018,11 @@ func TestParseMultiFloat64FromEnvCascade(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run"})
|
||||||
a.Run([]string{"run"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiBool(t *testing.T) {
|
func TestParseMultiBool(t *testing.T) {
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
BoolFlag{Name: "serve, s"},
|
BoolFlag{Name: "serve, s"},
|
||||||
},
|
},
|
||||||
@ -1044,15 +1035,14 @@ func TestParseMultiBool(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run", "--serve"})
|
||||||
a.Run([]string{"run", "--serve"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseBoolShortOptionHandle(t *testing.T) {
|
func TestParseBoolShortOptionHandle(t *testing.T) {
|
||||||
a := App{
|
_ = (&App{
|
||||||
Commands: []Command{
|
Commands: []Command{
|
||||||
{
|
{
|
||||||
Name: "foobar",
|
Name: "foobar",
|
||||||
UseShortOptionHandling: true,
|
UseShortOptionHandling: true,
|
||||||
Action: func(ctx *Context) error {
|
Action: func(ctx *Context) error {
|
||||||
if ctx.Bool("serve") != true {
|
if ctx.Bool("serve") != true {
|
||||||
@ -1069,13 +1059,12 @@ func TestParseBoolShortOptionHandle(t *testing.T) {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run", "foobar", "-so"})
|
||||||
a.Run([]string{"run", "foobar", "-so"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseDestinationBool(t *testing.T) {
|
func TestParseDestinationBool(t *testing.T) {
|
||||||
var dest bool
|
var dest bool
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
BoolFlag{
|
BoolFlag{
|
||||||
Name: "dest",
|
Name: "dest",
|
||||||
@ -1088,14 +1077,13 @@ func TestParseDestinationBool(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run", "--dest"})
|
||||||
a.Run([]string{"run", "--dest"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiBoolFromEnv(t *testing.T) {
|
func TestParseMultiBoolFromEnv(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_DEBUG", "1")
|
_ = os.Setenv("APP_DEBUG", "1")
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
BoolFlag{Name: "debug, d", EnvVar: "APP_DEBUG"},
|
BoolFlag{Name: "debug, d", EnvVar: "APP_DEBUG"},
|
||||||
},
|
},
|
||||||
@ -1108,14 +1096,13 @@ func TestParseMultiBoolFromEnv(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run"})
|
||||||
a.Run([]string{"run"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiBoolFromEnvCascade(t *testing.T) {
|
func TestParseMultiBoolFromEnvCascade(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_DEBUG", "1")
|
os.Setenv("APP_DEBUG", "1")
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
BoolFlag{Name: "debug, d", EnvVar: "COMPAT_DEBUG,APP_DEBUG"},
|
BoolFlag{Name: "debug, d", EnvVar: "COMPAT_DEBUG,APP_DEBUG"},
|
||||||
},
|
},
|
||||||
@ -1128,8 +1115,7 @@ func TestParseMultiBoolFromEnvCascade(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run"})
|
||||||
a.Run([]string{"run"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseBoolTFromEnv(t *testing.T) {
|
func TestParseBoolTFromEnv(t *testing.T) {
|
||||||
@ -1145,8 +1131,8 @@ func TestParseBoolTFromEnv(t *testing.T) {
|
|||||||
|
|
||||||
for _, test := range boolTFlagTests {
|
for _, test := range boolTFlagTests {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("DEBUG", test.input)
|
_ = os.Setenv("DEBUG", test.input)
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
BoolTFlag{Name: "debug, d", EnvVar: "DEBUG"},
|
BoolTFlag{Name: "debug, d", EnvVar: "DEBUG"},
|
||||||
},
|
},
|
||||||
@ -1159,13 +1145,12 @@ func TestParseBoolTFromEnv(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run"})
|
||||||
a.Run([]string{"run"})
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiBoolT(t *testing.T) {
|
func TestParseMultiBoolT(t *testing.T) {
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
BoolTFlag{Name: "serve, s"},
|
BoolTFlag{Name: "serve, s"},
|
||||||
},
|
},
|
||||||
@ -1178,13 +1163,12 @@ func TestParseMultiBoolT(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run", "--serve"})
|
||||||
a.Run([]string{"run", "--serve"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseDestinationBoolT(t *testing.T) {
|
func TestParseDestinationBoolT(t *testing.T) {
|
||||||
var dest bool
|
var dest bool
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
BoolTFlag{
|
BoolTFlag{
|
||||||
Name: "dest",
|
Name: "dest",
|
||||||
@ -1197,14 +1181,13 @@ func TestParseDestinationBoolT(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run", "--dest"})
|
||||||
a.Run([]string{"run", "--dest"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiBoolTFromEnv(t *testing.T) {
|
func TestParseMultiBoolTFromEnv(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_DEBUG", "0")
|
_ = os.Setenv("APP_DEBUG", "0")
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
BoolTFlag{Name: "debug, d", EnvVar: "APP_DEBUG"},
|
BoolTFlag{Name: "debug, d", EnvVar: "APP_DEBUG"},
|
||||||
},
|
},
|
||||||
@ -1217,14 +1200,13 @@ func TestParseMultiBoolTFromEnv(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run"})
|
||||||
a.Run([]string{"run"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseMultiBoolTFromEnvCascade(t *testing.T) {
|
func TestParseMultiBoolTFromEnvCascade(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_DEBUG", "0")
|
_ = os.Setenv("APP_DEBUG", "0")
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
BoolTFlag{Name: "debug, d", EnvVar: "COMPAT_DEBUG,APP_DEBUG"},
|
BoolTFlag{Name: "debug, d", EnvVar: "COMPAT_DEBUG,APP_DEBUG"},
|
||||||
},
|
},
|
||||||
@ -1237,8 +1219,7 @@ func TestParseMultiBoolTFromEnvCascade(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run"})
|
||||||
a.Run([]string{"run"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type Parser [2]string
|
type Parser [2]string
|
||||||
@ -1264,7 +1245,7 @@ func (p *Parser) Get() interface{} {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestParseGeneric(t *testing.T) {
|
func TestParseGeneric(t *testing.T) {
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
GenericFlag{Name: "serve, s", Value: &Parser{}},
|
GenericFlag{Name: "serve, s", Value: &Parser{}},
|
||||||
},
|
},
|
||||||
@ -1277,14 +1258,13 @@ func TestParseGeneric(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run", "-s", "10,20"})
|
||||||
a.Run([]string{"run", "-s", "10,20"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseGenericFromEnv(t *testing.T) {
|
func TestParseGenericFromEnv(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_SERVE", "20,30")
|
_ = os.Setenv("APP_SERVE", "20,30")
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
GenericFlag{Name: "serve, s", Value: &Parser{}, EnvVar: "APP_SERVE"},
|
GenericFlag{Name: "serve, s", Value: &Parser{}, EnvVar: "APP_SERVE"},
|
||||||
},
|
},
|
||||||
@ -1297,14 +1277,13 @@ func TestParseGenericFromEnv(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run"})
|
||||||
a.Run([]string{"run"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseGenericFromEnvCascade(t *testing.T) {
|
func TestParseGenericFromEnvCascade(t *testing.T) {
|
||||||
os.Clearenv()
|
os.Clearenv()
|
||||||
os.Setenv("APP_FOO", "99,2000")
|
_ = os.Setenv("APP_FOO", "99,2000")
|
||||||
a := App{
|
_ = (&App{
|
||||||
Flags: []Flag{
|
Flags: []Flag{
|
||||||
GenericFlag{Name: "foos", Value: &Parser{}, EnvVar: "COMPAT_FOO,APP_FOO"},
|
GenericFlag{Name: "foos", Value: &Parser{}, EnvVar: "COMPAT_FOO,APP_FOO"},
|
||||||
},
|
},
|
||||||
@ -1314,8 +1293,7 @@ func TestParseGenericFromEnvCascade(t *testing.T) {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}).Run([]string{"run"})
|
||||||
a.Run([]string{"run"})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFlagFromFile(t *testing.T) {
|
func TestFlagFromFile(t *testing.T) {
|
||||||
@ -1327,10 +1305,10 @@ func TestFlagFromFile(t *testing.T) {
|
|||||||
t.Error(err)
|
t.Error(err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
io.WriteString(temp, "abc")
|
_, _ = io.WriteString(temp, "abc")
|
||||||
temp.Close()
|
_ = temp.Close()
|
||||||
defer func() {
|
defer func() {
|
||||||
os.Remove(temp.Name())
|
_ = os.Remove(temp.Name())
|
||||||
}()
|
}()
|
||||||
|
|
||||||
var filePathTests = []struct {
|
var filePathTests = []struct {
|
||||||
|
22
help.go
22
help.go
@ -21,7 +21,7 @@ var helpCommand = Command{
|
|||||||
return ShowCommandHelp(c, args.First())
|
return ShowCommandHelp(c, args.First())
|
||||||
}
|
}
|
||||||
|
|
||||||
ShowAppHelp(c)
|
_ = ShowAppHelp(c)
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
@ -61,7 +61,7 @@ var VersionPrinter = printVersion
|
|||||||
|
|
||||||
// ShowAppHelpAndExit - Prints the list of subcommands for the app and exits with exit code.
|
// ShowAppHelpAndExit - Prints the list of subcommands for the app and exits with exit code.
|
||||||
func ShowAppHelpAndExit(c *Context, exitCode int) {
|
func ShowAppHelpAndExit(c *Context, exitCode int) {
|
||||||
ShowAppHelp(c)
|
_ = ShowAppHelp(c)
|
||||||
os.Exit(exitCode)
|
os.Exit(exitCode)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -95,11 +95,11 @@ func printCommandSuggestions(commands []Command, writer io.Writer) {
|
|||||||
}
|
}
|
||||||
if os.Getenv("_CLI_ZSH_AUTOCOMPLETE_HACK") == "1" {
|
if os.Getenv("_CLI_ZSH_AUTOCOMPLETE_HACK") == "1" {
|
||||||
for _, name := range command.Names() {
|
for _, name := range command.Names() {
|
||||||
fmt.Fprintf(writer, "%s:%s\n", name, command.Usage)
|
_, _ = fmt.Fprintf(writer, "%s:%s\n", name, command.Usage)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
for _, name := range command.Names() {
|
for _, name := range command.Names() {
|
||||||
fmt.Fprintf(writer, "%s\n", name)
|
_, _ = fmt.Fprintf(writer, "%s\n", name)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -144,7 +144,7 @@ func printFlagSuggestions(lastArg string, flags []Flag, writer io.Writer) {
|
|||||||
// match if last argument matches this flag and it is not repeated
|
// match if last argument matches this flag and it is not repeated
|
||||||
if strings.HasPrefix(name, cur) && cur != name && !cliArgContains(flag.GetName()) {
|
if strings.HasPrefix(name, cur) && cur != name && !cliArgContains(flag.GetName()) {
|
||||||
flagCompletion := fmt.Sprintf("%s%s", strings.Repeat("-", count), name)
|
flagCompletion := fmt.Sprintf("%s%s", strings.Repeat("-", count), name)
|
||||||
fmt.Fprintln(writer, flagCompletion)
|
_, _ = fmt.Fprintln(writer, flagCompletion)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -172,7 +172,7 @@ func DefaultCompleteWithFlags(cmd *Command) func(c *Context) {
|
|||||||
|
|
||||||
// ShowCommandHelpAndExit - exits with code after showing help
|
// ShowCommandHelpAndExit - exits with code after showing help
|
||||||
func ShowCommandHelpAndExit(c *Context, command string, code int) {
|
func ShowCommandHelpAndExit(c *Context, command string, code int) {
|
||||||
ShowCommandHelp(c, command)
|
_ = ShowCommandHelp(c, command)
|
||||||
os.Exit(code)
|
os.Exit(code)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -214,7 +214,7 @@ func ShowVersion(c *Context) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func printVersion(c *Context) {
|
func printVersion(c *Context) {
|
||||||
fmt.Fprintf(c.App.Writer, "%v version %v\n", c.App.Name, c.App.Version)
|
_, _ = fmt.Fprintf(c.App.Writer, "%v version %v\n", c.App.Name, c.App.Version)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ShowCompletions prints the lists of commands within a given context
|
// ShowCompletions prints the lists of commands within a given context
|
||||||
@ -253,11 +253,11 @@ func printHelpCustom(out io.Writer, templ string, data interface{}, customFunc m
|
|||||||
// If the writer is closed, t.Execute will fail, and there's nothing
|
// If the writer is closed, t.Execute will fail, and there's nothing
|
||||||
// we can do to recover.
|
// we can do to recover.
|
||||||
if os.Getenv("CLI_TEMPLATE_ERROR_DEBUG") != "" {
|
if os.Getenv("CLI_TEMPLATE_ERROR_DEBUG") != "" {
|
||||||
fmt.Fprintf(ErrWriter, "CLI TEMPLATE ERROR: %#v\n", err)
|
_, _ = fmt.Fprintf(ErrWriter, "CLI TEMPLATE ERROR: %#v\n", err)
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
w.Flush()
|
_ = w.Flush()
|
||||||
}
|
}
|
||||||
|
|
||||||
func printHelp(out io.Writer, templ string, data interface{}) {
|
func printHelp(out io.Writer, templ string, data interface{}) {
|
||||||
@ -290,7 +290,7 @@ func checkHelp(c *Context) bool {
|
|||||||
|
|
||||||
func checkCommandHelp(c *Context, name string) bool {
|
func checkCommandHelp(c *Context, name string) bool {
|
||||||
if c.Bool("h") || c.Bool("help") {
|
if c.Bool("h") || c.Bool("help") {
|
||||||
ShowCommandHelp(c, name)
|
_ = ShowCommandHelp(c, name)
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -299,7 +299,7 @@ func checkCommandHelp(c *Context, name string) bool {
|
|||||||
|
|
||||||
func checkSubcommandHelp(c *Context) bool {
|
func checkSubcommandHelp(c *Context) bool {
|
||||||
if c.Bool("h") || c.Bool("help") {
|
if c.Bool("h") || c.Bool("help") {
|
||||||
ShowSubcommandHelp(c)
|
_ = ShowSubcommandHelp(c)
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
38
help_test.go
38
help_test.go
@ -16,9 +16,9 @@ func Test_ShowAppHelp_NoAuthor(t *testing.T) {
|
|||||||
|
|
||||||
c := NewContext(app, nil, nil)
|
c := NewContext(app, nil, nil)
|
||||||
|
|
||||||
ShowAppHelp(c)
|
_ = ShowAppHelp(c)
|
||||||
|
|
||||||
if bytes.Index(output.Bytes(), []byte("AUTHOR(S):")) != -1 {
|
if bytes.Contains(output.Bytes(), []byte("AUTHOR(S):")) {
|
||||||
t.Errorf("expected\n%snot to include %s", output.String(), "AUTHOR(S):")
|
t.Errorf("expected\n%snot to include %s", output.String(), "AUTHOR(S):")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -32,9 +32,9 @@ func Test_ShowAppHelp_NoVersion(t *testing.T) {
|
|||||||
|
|
||||||
c := NewContext(app, nil, nil)
|
c := NewContext(app, nil, nil)
|
||||||
|
|
||||||
ShowAppHelp(c)
|
_ = ShowAppHelp(c)
|
||||||
|
|
||||||
if bytes.Index(output.Bytes(), []byte("VERSION:")) != -1 {
|
if bytes.Contains(output.Bytes(), []byte("VERSION:")) {
|
||||||
t.Errorf("expected\n%snot to include %s", output.String(), "VERSION:")
|
t.Errorf("expected\n%snot to include %s", output.String(), "VERSION:")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -48,9 +48,9 @@ func Test_ShowAppHelp_HideVersion(t *testing.T) {
|
|||||||
|
|
||||||
c := NewContext(app, nil, nil)
|
c := NewContext(app, nil, nil)
|
||||||
|
|
||||||
ShowAppHelp(c)
|
_ = ShowAppHelp(c)
|
||||||
|
|
||||||
if bytes.Index(output.Bytes(), []byte("VERSION:")) != -1 {
|
if bytes.Contains(output.Bytes(), []byte("VERSION:")) {
|
||||||
t.Errorf("expected\n%snot to include %s", output.String(), "VERSION:")
|
t.Errorf("expected\n%snot to include %s", output.String(), "VERSION:")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -79,7 +79,7 @@ func Test_Help_Custom_Flags(t *testing.T) {
|
|||||||
}
|
}
|
||||||
output := new(bytes.Buffer)
|
output := new(bytes.Buffer)
|
||||||
app.Writer = output
|
app.Writer = output
|
||||||
app.Run([]string{"test", "-h"})
|
_ = app.Run([]string{"test", "-h"})
|
||||||
if output.Len() > 0 {
|
if output.Len() > 0 {
|
||||||
t.Errorf("unexpected output: %s", output.String())
|
t.Errorf("unexpected output: %s", output.String())
|
||||||
}
|
}
|
||||||
@ -109,7 +109,7 @@ func Test_Version_Custom_Flags(t *testing.T) {
|
|||||||
}
|
}
|
||||||
output := new(bytes.Buffer)
|
output := new(bytes.Buffer)
|
||||||
app.Writer = output
|
app.Writer = output
|
||||||
app.Run([]string{"test", "-v"})
|
_ = app.Run([]string{"test", "-v"})
|
||||||
if output.Len() > 0 {
|
if output.Len() > 0 {
|
||||||
t.Errorf("unexpected output: %s", output.String())
|
t.Errorf("unexpected output: %s", output.String())
|
||||||
}
|
}
|
||||||
@ -119,7 +119,7 @@ func Test_helpCommand_Action_ErrorIfNoTopic(t *testing.T) {
|
|||||||
app := NewApp()
|
app := NewApp()
|
||||||
|
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
set.Parse([]string{"foo"})
|
_ = set.Parse([]string{"foo"})
|
||||||
|
|
||||||
c := NewContext(app, set, nil)
|
c := NewContext(app, set, nil)
|
||||||
|
|
||||||
@ -147,7 +147,7 @@ func Test_helpCommand_InHelpOutput(t *testing.T) {
|
|||||||
app := NewApp()
|
app := NewApp()
|
||||||
output := &bytes.Buffer{}
|
output := &bytes.Buffer{}
|
||||||
app.Writer = output
|
app.Writer = output
|
||||||
app.Run([]string{"test", "--help"})
|
_ = app.Run([]string{"test", "--help"})
|
||||||
|
|
||||||
s := output.String()
|
s := output.String()
|
||||||
|
|
||||||
@ -164,7 +164,7 @@ func Test_helpSubcommand_Action_ErrorIfNoTopic(t *testing.T) {
|
|||||||
app := NewApp()
|
app := NewApp()
|
||||||
|
|
||||||
set := flag.NewFlagSet("test", 0)
|
set := flag.NewFlagSet("test", 0)
|
||||||
set.Parse([]string{"foo"})
|
_ = set.Parse([]string{"foo"})
|
||||||
|
|
||||||
c := NewContext(app, set, nil)
|
c := NewContext(app, set, nil)
|
||||||
|
|
||||||
@ -203,7 +203,7 @@ func TestShowAppHelp_CommandAliases(t *testing.T) {
|
|||||||
|
|
||||||
output := &bytes.Buffer{}
|
output := &bytes.Buffer{}
|
||||||
app.Writer = output
|
app.Writer = output
|
||||||
app.Run([]string{"foo", "--help"})
|
_ = app.Run([]string{"foo", "--help"})
|
||||||
|
|
||||||
if !strings.Contains(output.String(), "frobbly, fr, frob") {
|
if !strings.Contains(output.String(), "frobbly, fr, frob") {
|
||||||
t.Errorf("expected output to include all command aliases; got: %q", output.String())
|
t.Errorf("expected output to include all command aliases; got: %q", output.String())
|
||||||
@ -225,7 +225,7 @@ func TestShowCommandHelp_CommandAliases(t *testing.T) {
|
|||||||
|
|
||||||
output := &bytes.Buffer{}
|
output := &bytes.Buffer{}
|
||||||
app.Writer = output
|
app.Writer = output
|
||||||
app.Run([]string{"foo", "help", "fr"})
|
_ = app.Run([]string{"foo", "help", "fr"})
|
||||||
|
|
||||||
if !strings.Contains(output.String(), "frobbly") {
|
if !strings.Contains(output.String(), "frobbly") {
|
||||||
t.Errorf("expected output to include command name; got: %q", output.String())
|
t.Errorf("expected output to include command name; got: %q", output.String())
|
||||||
@ -251,7 +251,7 @@ func TestShowSubcommandHelp_CommandAliases(t *testing.T) {
|
|||||||
|
|
||||||
output := &bytes.Buffer{}
|
output := &bytes.Buffer{}
|
||||||
app.Writer = output
|
app.Writer = output
|
||||||
app.Run([]string{"foo", "help"})
|
_ = app.Run([]string{"foo", "help"})
|
||||||
|
|
||||||
if !strings.Contains(output.String(), "frobbly, fr, frob, bork") {
|
if !strings.Contains(output.String(), "frobbly, fr, frob, bork") {
|
||||||
t.Errorf("expected output to include all command aliases; got: %q", output.String())
|
t.Errorf("expected output to include all command aliases; got: %q", output.String())
|
||||||
@ -285,7 +285,7 @@ EXAMPLES:
|
|||||||
}
|
}
|
||||||
output := &bytes.Buffer{}
|
output := &bytes.Buffer{}
|
||||||
app.Writer = output
|
app.Writer = output
|
||||||
app.Run([]string{"foo", "help", "frobbly"})
|
_ = app.Run([]string{"foo", "help", "frobbly"})
|
||||||
|
|
||||||
if strings.Contains(output.String(), "2. Frobbly runs without this param locally.") {
|
if strings.Contains(output.String(), "2. Frobbly runs without this param locally.") {
|
||||||
t.Errorf("expected output to exclude \"2. Frobbly runs without this param locally.\"; got: %q", output.String())
|
t.Errorf("expected output to exclude \"2. Frobbly runs without this param locally.\"; got: %q", output.String())
|
||||||
@ -313,7 +313,7 @@ func TestShowSubcommandHelp_CommandUsageText(t *testing.T) {
|
|||||||
output := &bytes.Buffer{}
|
output := &bytes.Buffer{}
|
||||||
app.Writer = output
|
app.Writer = output
|
||||||
|
|
||||||
app.Run([]string{"foo", "frobbly", "--help"})
|
_ = app.Run([]string{"foo", "frobbly", "--help"})
|
||||||
|
|
||||||
if !strings.Contains(output.String(), "this is usage text") {
|
if !strings.Contains(output.String(), "this is usage text") {
|
||||||
t.Errorf("expected output to include usage text; got: %q", output.String())
|
t.Errorf("expected output to include usage text; got: %q", output.String())
|
||||||
@ -337,7 +337,7 @@ func TestShowSubcommandHelp_SubcommandUsageText(t *testing.T) {
|
|||||||
|
|
||||||
output := &bytes.Buffer{}
|
output := &bytes.Buffer{}
|
||||||
app.Writer = output
|
app.Writer = output
|
||||||
app.Run([]string{"foo", "frobbly", "bobbly", "--help"})
|
_ = app.Run([]string{"foo", "frobbly", "bobbly", "--help"})
|
||||||
|
|
||||||
if !strings.Contains(output.String(), "this is usage text") {
|
if !strings.Contains(output.String(), "this is usage text") {
|
||||||
t.Errorf("expected output to include usage text; got: %q", output.String())
|
t.Errorf("expected output to include usage text; got: %q", output.String())
|
||||||
@ -365,7 +365,7 @@ func TestShowAppHelp_HiddenCommand(t *testing.T) {
|
|||||||
|
|
||||||
output := &bytes.Buffer{}
|
output := &bytes.Buffer{}
|
||||||
app.Writer = output
|
app.Writer = output
|
||||||
app.Run([]string{"app", "--help"})
|
_ = app.Run([]string{"app", "--help"})
|
||||||
|
|
||||||
if strings.Contains(output.String(), "secretfrob") {
|
if strings.Contains(output.String(), "secretfrob") {
|
||||||
t.Errorf("expected output to exclude \"secretfrob\"; got: %q", output.String())
|
t.Errorf("expected output to exclude \"secretfrob\"; got: %q", output.String())
|
||||||
@ -423,7 +423,7 @@ VERSION:
|
|||||||
|
|
||||||
output := &bytes.Buffer{}
|
output := &bytes.Buffer{}
|
||||||
app.Writer = output
|
app.Writer = output
|
||||||
app.Run([]string{"app", "--help"})
|
_ = app.Run([]string{"app", "--help"})
|
||||||
|
|
||||||
if strings.Contains(output.String(), "secretfrob") {
|
if strings.Contains(output.String(), "secretfrob") {
|
||||||
t.Errorf("expected output to exclude \"secretfrob\"; got: %q", output.String())
|
t.Errorf("expected output to exclude \"secretfrob\"; got: %q", output.String())
|
||||||
|
Loading…
Reference in New Issue
Block a user