Custom type for arguments
This commit is contained in:
parent
fbbda7a902
commit
1bea6dcbf0
4
app.go
4
app.go
@ -86,8 +86,8 @@ func (a *App) Run(arguments []string) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
args := context.Args()
|
args := context.Args()
|
||||||
if len(args) > 0 {
|
if args.Present() {
|
||||||
name := args[0]
|
name := args.First()
|
||||||
c := a.Command(name)
|
c := a.Command(name)
|
||||||
if c != nil {
|
if c != nil {
|
||||||
return c.Run(context)
|
return c.Run(context)
|
||||||
|
@ -29,7 +29,7 @@ func TestApp_Run(t *testing.T) {
|
|||||||
|
|
||||||
app := cli.NewApp()
|
app := cli.NewApp()
|
||||||
app.Action = func(c *cli.Context) {
|
app.Action = func(c *cli.Context) {
|
||||||
s = s + c.Args()[0]
|
s = s + c.Args().First()
|
||||||
}
|
}
|
||||||
|
|
||||||
err := app.Run([]string{"command", "foo"})
|
err := app.Run([]string{"command", "foo"})
|
||||||
@ -76,7 +76,7 @@ func TestApp_CommandWithArgBeforeFlags(t *testing.T) {
|
|||||||
},
|
},
|
||||||
Action: func(c *cli.Context) {
|
Action: func(c *cli.Context) {
|
||||||
parsedOption = c.String("option")
|
parsedOption = c.String("option")
|
||||||
firstArg = c.Args()[0]
|
firstArg = c.Args().First()
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
app.Commands = []cli.Command{command}
|
app.Commands = []cli.Command{command}
|
||||||
@ -103,7 +103,7 @@ func TestApp_ParseSliceFlags(t *testing.T) {
|
|||||||
parsedIntSlice = c.IntSlice("p")
|
parsedIntSlice = c.IntSlice("p")
|
||||||
parsedStringSlice = c.StringSlice("ip")
|
parsedStringSlice = c.StringSlice("ip")
|
||||||
parsedOption = c.String("option")
|
parsedOption = c.String("option")
|
||||||
firstArg = c.Args()[0]
|
firstArg = c.Args().First()
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
app.Commands = []cli.Command{command}
|
app.Commands = []cli.Command{command}
|
||||||
|
@ -15,7 +15,7 @@ func Example() {
|
|||||||
ShortName: "a",
|
ShortName: "a",
|
||||||
Usage: "add a task to the list",
|
Usage: "add a task to the list",
|
||||||
Action: func(c *cli.Context) {
|
Action: func(c *cli.Context) {
|
||||||
println("added task: ", c.Args()[0])
|
println("added task: ", c.Args().First())
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -23,7 +23,7 @@ func Example() {
|
|||||||
ShortName: "c",
|
ShortName: "c",
|
||||||
Usage: "complete a task on the list",
|
Usage: "complete a task on the list",
|
||||||
Action: func(c *cli.Context) {
|
Action: func(c *cli.Context) {
|
||||||
println("completed task: ", c.Args()[0])
|
println("completed task: ", c.Args().First())
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -43,11 +43,12 @@ func (c Command) Run(ctx *Context) error {
|
|||||||
|
|
||||||
var err error
|
var err error
|
||||||
if firstFlagIndex > -1 {
|
if firstFlagIndex > -1 {
|
||||||
args := ctx.Args()[1:firstFlagIndex]
|
args := ctx.Args()
|
||||||
flags := ctx.Args()[firstFlagIndex:]
|
regularArgs := args[1:firstFlagIndex]
|
||||||
err = set.Parse(append(flags, args...))
|
flagArgs := args[firstFlagIndex:]
|
||||||
|
err = set.Parse(append(flagArgs, regularArgs...))
|
||||||
} else {
|
} else {
|
||||||
err = set.Parse(ctx.Args()[1:])
|
err = set.Parse(ctx.Args().Tail())
|
||||||
}
|
}
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
36
context.go
36
context.go
@ -15,6 +15,8 @@ type Context struct {
|
|||||||
globalSet *flag.FlagSet
|
globalSet *flag.FlagSet
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type Args []string
|
||||||
|
|
||||||
// Creates a new context. For use in when invoking an App or Command action.
|
// Creates a new context. For use in when invoking an App or Command action.
|
||||||
func NewContext(app *App, set *flag.FlagSet, globalSet *flag.FlagSet) *Context {
|
func NewContext(app *App, set *flag.FlagSet, globalSet *flag.FlagSet) *Context {
|
||||||
return &Context{app, set, globalSet}
|
return &Context{app, set, globalSet}
|
||||||
@ -71,8 +73,9 @@ func (c *Context) GlobalIntSlice(name string) []int {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Returns the command line arguments associated with the context.
|
// Returns the command line arguments associated with the context.
|
||||||
func (c *Context) Args() []string {
|
func (c *Context) Args() Args {
|
||||||
return c.flagSet.Args()
|
args := Args(c.flagSet.Args())
|
||||||
|
return args
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Context) lookupInt(name string, set *flag.FlagSet) int {
|
func (c *Context) lookupInt(name string, set *flag.FlagSet) int {
|
||||||
@ -130,16 +133,29 @@ func (c *Context) lookupBool(name string, set *flag.FlagSet) bool {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns the nth argument, or just a blank string
|
// Returns the nth argument, or else a blank string
|
||||||
func (c *Context) GetArg(n int) string {
|
func (a Args) Get(n int) string {
|
||||||
args := c.Args()
|
if len(a) > n {
|
||||||
if len(args) < n {
|
return a[n]
|
||||||
return args[n]
|
|
||||||
}
|
}
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns the first argument, or just a blank string, for convenience
|
// Returns the first argument, or else a blank string
|
||||||
func (c *Context) FirstArg() string {
|
func (a Args) First() string {
|
||||||
return c.GetArg(0)
|
return a.Get(0)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return the rest of the arguments (not the first one)
|
||||||
|
// or else an empty string slice
|
||||||
|
func (a Args) Tail() []string {
|
||||||
|
if len(a) >= 2 {
|
||||||
|
return []string(a)[1:]
|
||||||
|
}
|
||||||
|
return []string{}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Checks if there are any arguments present
|
||||||
|
func (a Args) Present() bool {
|
||||||
|
return len(a) != 0
|
||||||
}
|
}
|
||||||
|
4
help.go
4
help.go
@ -76,8 +76,8 @@ var helpCommand = Command{
|
|||||||
Usage: "Shows a list of commands or help for one command",
|
Usage: "Shows a list of commands or help for one command",
|
||||||
Action: func(c *Context) {
|
Action: func(c *Context) {
|
||||||
args := c.Args()
|
args := c.Args()
|
||||||
if len(args) > 0 {
|
if args.Present() {
|
||||||
ShowCommandHelp(c, args[0])
|
ShowCommandHelp(c, args.First())
|
||||||
} else {
|
} else {
|
||||||
ShowAppHelp(c)
|
ShowAppHelp(c)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user