Add additional test for log flag completion and comments

This commit is contained in:
Yogesh Lonkar 2019-08-05 20:18:08 +02:00
parent c3f51bed6f
commit 2be2bc755e
No known key found for this signature in database
GPG Key ID: A08E266247F12F6A
2 changed files with 38 additions and 5 deletions

View File

@ -274,6 +274,35 @@ func ExampleApp_Run_bashComplete_withLongFlag() {
// --some-flag // --some-flag
// --similar-flag // --similar-flag
} }
func ExampleApp_Run_bashComplete_withMultipleLongFlag() {
os.Args = []string{"greet", "--st", "--generate-bash-completion"}
app := NewApp()
app.Name = "greet"
app.EnableBashCompletion = true
app.Flags = []Flag{
IntFlag{
Name: "int-flag,i",
},
StringFlag{
Name: "string,s",
},
StringFlag{
Name: "string-flag-2",
},
StringFlag{
Name: "similar-flag",
},
StringFlag{
Name: "some-flag",
},
}
app.Run(os.Args)
// Output:
// --string
// --string-flag-2
}
func ExampleApp_Run_bashComplete() { func ExampleApp_Run_bashComplete() {
// set args for examples sake // set args for examples sake

14
help.go
View File

@ -199,23 +199,27 @@ func cliArgContains(flagName string) bool {
} }
func printFlagSuggestions(lastArg string, flags []Flag, writer io.Writer) { func printFlagSuggestions(lastArg string, flags []Flag, writer io.Writer) {
cur := shortFlagRegex.ReplaceAllString(lastArg, "") cur := strings.TrimPrefix(lastArg, "-")
cur = shortFlagRegex.ReplaceAllString(cur, "") cur = strings.TrimPrefix(cur, "-")
for _, flag := range flags { for _, flag := range flags {
if bflag, ok := flag.(BoolFlag); ok && bflag.Hidden { if bflag, ok := flag.(BoolFlag); ok && bflag.Hidden {
continue continue
} }
for _, name := range strings.Split(flag.GetName(), ",") { for _, name := range strings.Split(flag.GetName(), ",") {
name = strings.Trim(name, " ") name = strings.TrimSpace(name)
// this will get total count utf8 letters in flag name
count := utf8.RuneCountInString(name) count := utf8.RuneCountInString(name)
if count > 2 { if count > 2 {
count = 2 count = 2 // resuse this count to generate single - or -- in flag completion
} }
// if flag name has more than one utf8 letter and last argument in cli has -- prefix then
// skip flag completion for short flags example -v or -x
if strings.HasPrefix(lastArg, "--") && count == 1 { if strings.HasPrefix(lastArg, "--") && count == 1 {
continue continue
} }
flagCompletion := fmt.Sprintf("%s%s", strings.Repeat("-", count), name) // match if last argument matches this flag and it is not repeated
if strings.HasPrefix(name, cur) && cur != name && !cliArgContains(flag.GetName()) { if strings.HasPrefix(name, cur) && cur != name && !cliArgContains(flag.GetName()) {
flagCompletion := fmt.Sprintf("%s%s", strings.Repeat("-", count), name)
fmt.Fprintln(writer, flagCompletion) fmt.Fprintln(writer, flagCompletion)
} }
} }