tag: add passthrough for positional arguments
This new tag tells the parser to stop processing flags after the positional argument is encountered. This is particularly useful for subcommands that forward their arguments to an external program, and makes it possible to implement commands like `kubectl exec` or `docker run`. Fixes #80.
This commit is contained in:
committed by
Alec Thomas
parent
49417fe966
commit
d4dd709445
@@ -207,6 +207,33 @@ func TestSliceConsumesRemainingPositionalArgs(t *testing.T) {
|
||||
require.Equal(t, []string{"ls", "-lart"}, cli.Remainder)
|
||||
}
|
||||
|
||||
func TestPassthroughStopsParsing(t *testing.T) {
|
||||
type cli struct {
|
||||
Interactive bool `short:"i"`
|
||||
Image string `arg:""`
|
||||
Argv []string `arg:"" optional:"" passthrough:""`
|
||||
}
|
||||
|
||||
var actual cli
|
||||
p := mustNew(t, &actual)
|
||||
|
||||
_, err := p.Parse([]string{"alpine", "sudo", "-i", "true"})
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, cli{
|
||||
Interactive: false,
|
||||
Image: "alpine",
|
||||
Argv: []string{"sudo", "-i", "true"},
|
||||
}, actual)
|
||||
|
||||
_, err = p.Parse([]string{"alpine", "-i", "sudo", "-i", "true"})
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, cli{
|
||||
Interactive: true,
|
||||
Image: "alpine",
|
||||
Argv: []string{"sudo", "-i", "true"},
|
||||
}, actual)
|
||||
}
|
||||
|
||||
type mappedValue struct {
|
||||
decoded string
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user