Custom type for arguments

This commit is contained in:
Alexander Rødseth 2013-11-24 14:40:21 +01:00
parent fbbda7a902
commit 1bea6dcbf0
6 changed files with 40 additions and 23 deletions

4
app.go
View File

@ -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)

View File

@ -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}

View File

@ -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())
}, },
}, },
} }

View File

@ -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 {

View File

@ -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
} }

View File

@ -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)
} }