Improve the CLI help (Update of the Flaeg dependency)

This commit is contained in:
Damien Duportal 2018-10-10 19:10:04 +02:00 committed by Traefiker Bot
parent b722748ec3
commit e8e9dd9400
4 changed files with 22 additions and 15 deletions

6
Gopkg.lock generated
View file

@ -283,8 +283,8 @@
".", ".",
"parse" "parse"
] ]
revision = "b4c2f060875361c070ed2bc300c5929b82f5fa2e" revision = "aad81c7ac7f49671a59b9ede8ab22436e132a302"
version = "v1.1.2" version = "v1.3.0"
[[projects]] [[projects]]
branch = "master" branch = "master"
@ -1818,6 +1818,6 @@
[solve-meta] [solve-meta]
analyzer-name = "dep" analyzer-name = "dep"
analyzer-version = 1 analyzer-version = 1
inputs-digest = "b75bf0ae5b8c1ae1ba578fe5a58dfc4cd4270e02f5ea3b9f0d5a92972a36e9b2" inputs-digest = "059f9d29d78e7a800b676c529197fd627de968837b01c663a8a00ee72c36271b"
solver-name = "gps-cdcl" solver-name = "gps-cdcl"
solver-version = 1 solver-version = 1

View file

@ -54,7 +54,7 @@
[[constraint]] [[constraint]]
name = "github.com/containous/flaeg" name = "github.com/containous/flaeg"
version = "1.0.1" version = "1.3.0"
[[constraint]] [[constraint]]
branch = "master" branch = "master"

View file

@ -32,7 +32,7 @@ find vendor -type f \( ! -iname 'licen[cs]e*' \
-a ! -iname '*.hxx' \ -a ! -iname '*.hxx' \
-a ! -iname '*.s' \) -exec rm -f {} + -a ! -iname '*.s' \) -exec rm -f {} +
find -type d \( -iname '*Godeps*' \) -exec rm -rf {} + find . -type d \( -iname '*Godeps*' \) -exec rm -rf {} +
find vendor -type l \( ! -iname 'licen[cs]e*' \ find vendor -type l \( ! -iname 'licen[cs]e*' \
-a ! -iname '*notice*' \ -a ! -iname '*notice*' \

View file

@ -396,6 +396,7 @@ type Command struct {
DefaultPointersConfig interface{} // TODO: case DefaultPointersConfig is nil DefaultPointersConfig interface{} // TODO: case DefaultPointersConfig is nil
Run func() error Run func() error
Metadata map[string]string Metadata map[string]string
HideHelp bool
} }
// LoadWithCommand initializes config : struct fields given by reference, with args : arguments. // LoadWithCommand initializes config : struct fields given by reference, with args : arguments.
@ -437,13 +438,16 @@ func PrintHelpWithCommand(flagMap map[string]reflect.StructField, defaultValMap
// Using POSXE STD : http://pubs.opengroup.org/onlinepubs/9699919799/ // Using POSXE STD : http://pubs.opengroup.org/onlinepubs/9699919799/
const helper = `{{if .ProgDescription}}{{.ProgDescription}} const helper = `{{if .ProgDescription}}{{.ProgDescription}}
{{end}}Usage: {{.ProgName}} [--flag=flag_argument] [-f[flag_argument]] ... set flag_argument to flag(s) {{end}}Usage: {{.ProgName}} [flags] <command> [<arguments>]
or: {{.ProgName}} [--flag[=true|false| ]] [-f[true|false| ]] ... set true/false to boolean flag(s)
Use "{{.ProgName}} <command> --help" for help on any command.
{{if .SubCommands}} {{if .SubCommands}}
Available Commands:{{range $subCmdName, $subCmdDesc := .SubCommands}} Commands:{{range $subCmdName, $subCmdDesc := .SubCommands}}
{{printf "\t%-50s %s" $subCmdName $subCmdDesc}}{{end}} {{printf "\t%-50s %s" $subCmdName $subCmdDesc}}{{end}}
Use "{{.ProgName}} [command] --help" for more information about a command.
{{end}} {{end}}
Flag's usage: {{.ProgName}} [--flag=flag_argument] [-f[flag_argument]] ... set flag_argument to flag(s)
or: {{.ProgName}} [--flag[=true|false| ]] [-f[true|false| ]] ... set true/false to boolean flag(s)
Flags: Flags:
` `
// Use a struct to give data to template // Use a struct to give data to template
@ -453,13 +457,15 @@ Flags:
SubCommands map[string]string SubCommands map[string]string
} }
tempStruct := TempStruct{} tempStruct := TempStruct{}
if cmd != nil { if cmd != nil && !cmd.HideHelp {
tempStruct.ProgName = cmd.Name tempStruct.ProgName = cmd.Name
tempStruct.ProgDescription = cmd.Description tempStruct.ProgDescription = cmd.Description
tempStruct.SubCommands = map[string]string{} tempStruct.SubCommands = map[string]string{}
if len(subCmd) > 1 && cmd == subCmd[0] { if len(subCmd) > 1 && cmd == subCmd[0] {
for _, c := range subCmd[1:] { for _, c := range subCmd[1:] {
tempStruct.SubCommands[c.Name] = c.Description if !c.HideHelp {
tempStruct.SubCommands[c.Name] = c.Description
}
} }
} }
} else { } else {
@ -528,7 +534,7 @@ func printFlagsDescriptionsDefaultValues(flagMap map[string]reflect.StructField,
} }
} }
//add help flag // add help flag
shortFlagsWithDash = append(shortFlagsWithDash, "-h,") shortFlagsWithDash = append(shortFlagsWithDash, "-h,")
flagsWithDash = append(flagsWithDash, "--help") flagsWithDash = append(flagsWithDash, "--help")
descriptions = append(descriptions, "Print Help (this message) and exit") descriptions = append(descriptions, "Print Help (this message) and exit")
@ -536,6 +542,7 @@ func printFlagsDescriptionsDefaultValues(flagMap map[string]reflect.StructField,
return displayTab(output, shortFlagsWithDash, flagsWithDash, descriptions, defaultValues) return displayTab(output, shortFlagsWithDash, flagsWithDash, descriptions, defaultValues)
} }
func split(str string, width int) []string { func split(str string, width int) []string {
if len(str) > width { if len(str) > width {
index := strings.LastIndex(str[:width], " ") index := strings.LastIndex(str[:width], " ")
@ -584,7 +591,7 @@ func PrintErrorWithCommand(err error, flagMap map[string]reflect.StructField, de
// a map of custom parsers could be use // a map of custom parsers could be use
type Flaeg struct { type Flaeg struct {
calledCommand *Command calledCommand *Command
commands []*Command ///rootCommand is th fist one in this slice commands []*Command // rootCommand is th fist one in this slice
args []string args []string
commandArgs []string commandArgs []string
customParsers map[reflect.Type]parse.Parser customParsers map[reflect.Type]parse.Parser
@ -654,7 +661,7 @@ func (f *Flaeg) findCommandWithCommandArgs() (*Command, []string, error) {
commandName, f.commandArgs = splitArgs(f.args) commandName, f.commandArgs = splitArgs(f.args)
if len(commandName) > 0 { if len(commandName) > 0 {
for _, command := range f.commands { for _, command := range f.commands {
if commandName == command.Name { if commandName == command.Name && !command.HideHelp {
f.calledCommand = command f.calledCommand = command
return f.calledCommand, f.commandArgs, nil return f.calledCommand, f.commandArgs, nil
} }