Add version option handling
This commit is contained in:
parent
b4759d5f08
commit
73d7db2078
16
command.go
16
command.go
|
@ -9,6 +9,7 @@ import (
|
||||||
|
|
||||||
type Command struct {
|
type Command struct {
|
||||||
Name string
|
Name string
|
||||||
|
version string
|
||||||
ShortDescription string
|
ShortDescription string
|
||||||
LongDescription string
|
LongDescription string
|
||||||
Aliases []string
|
Aliases []string
|
||||||
|
@ -20,8 +21,8 @@ type Command struct {
|
||||||
isRoot bool
|
isRoot bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewRoot(name string, options ...Option) *Command {
|
func NewRoot(name string, version string, options ...Option) *Command {
|
||||||
cmd := &Command{Name: name, isRoot: true}
|
cmd := &Command{Name: name, version: version, isRoot: true}
|
||||||
cmd.ApplyOptions(options...)
|
cmd.ApplyOptions(options...)
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
@ -91,6 +92,12 @@ func (c *Command) Execute(args []string) {
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
versionOpt, ok := opt.Globals().GetBool("version")
|
||||||
|
if ok && versionOpt.Value() {
|
||||||
|
c.ShowVersion()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
helpOpt, ok := opt.Globals().GetBool("help")
|
helpOpt, ok := opt.Globals().GetBool("help")
|
||||||
if ok && helpOpt.Value() {
|
if ok && helpOpt.Value() {
|
||||||
c.ShowHelp()
|
c.ShowHelp()
|
||||||
|
@ -104,3 +111,8 @@ func (c *Command) Execute(args []string) {
|
||||||
|
|
||||||
c.ShowHelp()
|
c.ShowHelp()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *Command) ShowVersion() {
|
||||||
|
rootName := c.Root().Name
|
||||||
|
fmt.Printf("%s %s\n", rootName, c.version)
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue