Merge pull request #697 from urfave/fix-skip-flag-parsing
Fix regression of SkipFlagParsing behavior
This commit is contained in:
commit
75104e932a
@ -178,7 +178,7 @@ func (c *Command) parseFlags(args Args) (*flag.FlagSet, error) {
|
|||||||
set.SetOutput(ioutil.Discard)
|
set.SetOutput(ioutil.Discard)
|
||||||
|
|
||||||
if c.SkipFlagParsing {
|
if c.SkipFlagParsing {
|
||||||
return set, set.Parse(append([]string{c.Name, "--"}, args...))
|
return set, set.Parse(append([]string{"--"}, args...))
|
||||||
}
|
}
|
||||||
|
|
||||||
if c.UseShortOptionHandling {
|
if c.UseShortOptionHandling {
|
||||||
|
@ -281,3 +281,39 @@ func TestCommandFlagReordering(t *testing.T) {
|
|||||||
expect(t, args, c.expectedArgs)
|
expect(t, args, c.expectedArgs)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestCommandSkipFlagParsing(t *testing.T) {
|
||||||
|
cases := []struct {
|
||||||
|
testArgs []string
|
||||||
|
expectedArgs []string
|
||||||
|
expectedErr error
|
||||||
|
}{
|
||||||
|
{[]string{"some-exec", "some-command", "some-arg", "--flag", "foo"}, []string{"some-arg", "--flag", "foo"}, nil},
|
||||||
|
{[]string{"some-exec", "some-command", "some-arg", "--flag=foo"}, []string{"some-arg", "--flag=foo"}, nil},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, c := range cases {
|
||||||
|
value := ""
|
||||||
|
args := []string{}
|
||||||
|
app := &App{
|
||||||
|
Commands: []Command{
|
||||||
|
{
|
||||||
|
SkipFlagParsing: true,
|
||||||
|
Name: "some-command",
|
||||||
|
Flags: []Flag{
|
||||||
|
StringFlag{Name: "flag"},
|
||||||
|
},
|
||||||
|
Action: func(c *Context) {
|
||||||
|
fmt.Printf("%+v\n", c.String("flag"))
|
||||||
|
value = c.String("flag")
|
||||||
|
args = c.Args()
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
err := app.Run(c.testArgs)
|
||||||
|
expect(t, err, c.expectedErr)
|
||||||
|
expect(t, args, c.expectedArgs)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user