Merge pull request #30 from codegangsta/JMS-28

JMS #28: -h flags for subcommands
This commit is contained in:
Jeremy Saenz 2013-08-14 09:26:03 -07:00
commit 16d10cc127
2 changed files with 18 additions and 1 deletions

View File

@ -10,9 +10,19 @@ type Command struct {
} }
func (c Command) Run(ctx *Context) { func (c Command) Run(ctx *Context) {
// append help to flags
c.Flags = append(
c.Flags,
helpFlag{"show help"},
)
set := flagSet(c.Name, c.Flags) set := flagSet(c.Name, c.Flags)
set.Parse(ctx.Args()[1:]) set.Parse(ctx.Args()[1:])
c.Action(NewContext(ctx.App, set, ctx.globalSet))
context := NewContext(ctx.App, set, ctx.globalSet)
checkCommandHelp(context, c.Name)
c.Action(context)
} }
func (c Command) HasName(name string) bool { func (c Command) HasName(name string) bool {

View File

@ -101,3 +101,10 @@ func checkHelp(c *Context) {
os.Exit(0) os.Exit(0)
} }
} }
func checkCommandHelp(c *Context, name string) {
if c.Bool("h") || c.Bool("help") {
ShowCommandHelp(c, name)
os.Exit(0)
}
}