JMS #25: Added support for help flags
This commit is contained in:
parent
933a037bf0
commit
70eacca641
19
app.go
19
app.go
@ -32,19 +32,22 @@ func (a *App) Run(arguments []string) {
|
|||||||
// append help to commands
|
// append help to commands
|
||||||
a.Commands = append(a.Commands, helpCommand)
|
a.Commands = append(a.Commands, helpCommand)
|
||||||
// append version to flags
|
// append version to flags
|
||||||
a.Flags = append(a.Flags, BoolFlag{"version", "print the version"})
|
a.Flags = append(
|
||||||
|
a.Flags,
|
||||||
|
BoolFlag{"version", "print the version"},
|
||||||
|
helpFlag{"show help"},
|
||||||
|
)
|
||||||
|
|
||||||
// parse flags
|
// parse flags
|
||||||
set := flagSet(a.Name, a.Flags)
|
set := flagSet(a.Name, a.Flags)
|
||||||
set.Parse(arguments[1:])
|
err := set.Parse(arguments[1:])
|
||||||
|
if err != nil {
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
|
||||||
context := NewContext(a, set, set)
|
context := NewContext(a, set, set)
|
||||||
|
checkHelp(context)
|
||||||
// check version
|
checkVersion(context)
|
||||||
if context.GlobalBool("version") {
|
|
||||||
showVersion(context)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
args := context.Args()
|
args := context.Args()
|
||||||
if len(args) > 0 {
|
if len(args) > 0 {
|
||||||
|
@ -62,7 +62,7 @@ func (c *Context) lookupInt(name string, set *flag.FlagSet) int {
|
|||||||
}
|
}
|
||||||
return val
|
return val
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -71,7 +71,7 @@ func (c *Context) lookupString(name string, set *flag.FlagSet) string {
|
|||||||
if f != nil {
|
if f != nil {
|
||||||
return f.Value.String()
|
return f.Value.String()
|
||||||
}
|
}
|
||||||
|
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -84,6 +84,6 @@ func (c *Context) lookupBool(name string, set *flag.FlagSet) bool {
|
|||||||
}
|
}
|
||||||
return val
|
return val
|
||||||
}
|
}
|
||||||
|
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
@ -2,8 +2,8 @@ package cli_test
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"flag"
|
"flag"
|
||||||
"testing"
|
|
||||||
"github.com/codegangsta/cli"
|
"github.com/codegangsta/cli"
|
||||||
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestNewContext(t *testing.T) {
|
func TestNewContext(t *testing.T) {
|
||||||
|
15
flag.go
15
flag.go
@ -9,7 +9,7 @@ type Flag interface {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func flagSet(name string, flags []Flag) *flag.FlagSet {
|
func flagSet(name string, flags []Flag) *flag.FlagSet {
|
||||||
set := flag.NewFlagSet(name, flag.ExitOnError)
|
set := flag.NewFlagSet(name, flag.ContinueOnError)
|
||||||
for _, f := range flags {
|
for _, f := range flags {
|
||||||
f.Apply(set)
|
f.Apply(set)
|
||||||
}
|
}
|
||||||
@ -56,3 +56,16 @@ func (f IntFlag) String() string {
|
|||||||
func (f IntFlag) Apply(set *flag.FlagSet) {
|
func (f IntFlag) Apply(set *flag.FlagSet) {
|
||||||
set.Int(f.Name, f.Value, f.Usage)
|
set.Int(f.Name, f.Value, f.Usage)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type helpFlag struct {
|
||||||
|
Usage string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f helpFlag) String() string {
|
||||||
|
return fmt.Sprintf("--help, -h\t%v", f.Usage)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f helpFlag) Apply(set *flag.FlagSet) {
|
||||||
|
set.Bool("h", false, f.Usage)
|
||||||
|
set.Bool("help", false, f.Usage)
|
||||||
|
}
|
||||||
|
34
help.go
34
help.go
@ -51,30 +51,36 @@ var helpCommand = Command{
|
|||||||
Action: func(c *Context) {
|
Action: func(c *Context) {
|
||||||
args := c.Args()
|
args := c.Args()
|
||||||
if len(args) > 0 {
|
if len(args) > 0 {
|
||||||
showCommandHelp(c)
|
ShowCommandHelp(c, args[0])
|
||||||
} else {
|
} else {
|
||||||
showAppHelp(c)
|
ShowAppHelp(c)
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
func showAppHelp(c *Context) {
|
// Prints help for the App
|
||||||
|
func ShowAppHelp(c *Context) {
|
||||||
printHelp(AppHelpTemplate, c.App)
|
printHelp(AppHelpTemplate, c.App)
|
||||||
}
|
}
|
||||||
|
|
||||||
func showCommandHelp(c *Context) {
|
// Prints help for the given command
|
||||||
name := c.Args()[0]
|
func ShowCommandHelp(c *Context, command string) {
|
||||||
for _, c := range c.App.Commands {
|
for _, c := range c.App.Commands {
|
||||||
if c.HasName(name) {
|
if c.HasName(command) {
|
||||||
printHelp(CommandHelpTemplate, c)
|
printHelp(CommandHelpTemplate, c)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Printf("No help topic for '%v'\n", name)
|
fmt.Printf("No help topic for '%v'\n", command)
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Prints the version number of the App
|
||||||
|
func ShowVersion(c *Context) {
|
||||||
|
fmt.Printf("%v version %v\n", c.App.Name, c.App.Version)
|
||||||
|
}
|
||||||
|
|
||||||
func printHelp(templ string, data interface{}) {
|
func printHelp(templ string, data interface{}) {
|
||||||
w := tabwriter.NewWriter(os.Stdout, 0, 8, 1, '\t', 0)
|
w := tabwriter.NewWriter(os.Stdout, 0, 8, 1, '\t', 0)
|
||||||
t := template.Must(template.New("help").Parse(templ))
|
t := template.Must(template.New("help").Parse(templ))
|
||||||
@ -82,6 +88,16 @@ func printHelp(templ string, data interface{}) {
|
|||||||
w.Flush()
|
w.Flush()
|
||||||
}
|
}
|
||||||
|
|
||||||
func showVersion(c *Context) {
|
func checkVersion(c *Context) {
|
||||||
fmt.Printf("%v version %v\n", c.App.Name, c.App.Version)
|
if c.GlobalBool("version") {
|
||||||
|
ShowVersion(c)
|
||||||
|
os.Exit(0)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func checkHelp(c *Context) {
|
||||||
|
if c.GlobalBool("h") || c.GlobalBool("help") {
|
||||||
|
ShowAppHelp(c)
|
||||||
|
os.Exit(0)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user