Merge pull request #1208 from Madhur1997/master
Display `(accepts multiple inputs)` in the help description for Slice flags.
This commit is contained in:
commit
795a8adacb
6
flag.go
6
flag.go
@ -359,7 +359,11 @@ func stringifySliceFlag(usage string, names, defaultVals []string) string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
usageWithDefault := strings.TrimSpace(fmt.Sprintf("%s%s", usage, defaultVal))
|
usageWithDefault := strings.TrimSpace(fmt.Sprintf("%s%s", usage, defaultVal))
|
||||||
return fmt.Sprintf("%s\t%s", prefixedNames(names, placeholder), usageWithDefault)
|
multiInputString := "(accepts multiple inputs)"
|
||||||
|
if usageWithDefault != "" {
|
||||||
|
multiInputString = "\t" + multiInputString
|
||||||
|
}
|
||||||
|
return fmt.Sprintf("%s\t%s%s", prefixedNames(names, placeholder), usageWithDefault, multiInputString)
|
||||||
}
|
}
|
||||||
|
|
||||||
func hasFlag(flags []Flag, fl Flag) bool {
|
func hasFlag(flags []Flag, fl Flag) bool {
|
||||||
|
28
flag_test.go
28
flag_test.go
@ -340,11 +340,11 @@ var stringSliceFlagTests = []struct {
|
|||||||
value *StringSlice
|
value *StringSlice
|
||||||
expected string
|
expected string
|
||||||
}{
|
}{
|
||||||
{"foo", nil, NewStringSlice(""), "--foo value\t"},
|
{"foo", nil, NewStringSlice(""), "--foo value\t(accepts multiple inputs)"},
|
||||||
{"f", nil, NewStringSlice(""), "-f value\t"},
|
{"f", nil, NewStringSlice(""), "-f value\t(accepts multiple inputs)"},
|
||||||
{"f", nil, NewStringSlice("Lipstick"), "-f value\t(default: \"Lipstick\")"},
|
{"f", nil, NewStringSlice("Lipstick"), "-f value\t(default: \"Lipstick\")\t(accepts multiple inputs)"},
|
||||||
{"test", nil, NewStringSlice("Something"), "--test value\t(default: \"Something\")"},
|
{"test", nil, NewStringSlice("Something"), "--test value\t(default: \"Something\")\t(accepts multiple inputs)"},
|
||||||
{"dee", []string{"d"}, NewStringSlice("Inka", "Dinka", "dooo"), "--dee value, -d value\t(default: \"Inka\", \"Dinka\", \"dooo\")"},
|
{"dee", []string{"d"}, NewStringSlice("Inka", "Dinka", "dooo"), "--dee value, -d value\t(default: \"Inka\", \"Dinka\", \"dooo\")\t(accepts multiple inputs)"},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestStringSliceFlagHelpOutput(t *testing.T) {
|
func TestStringSliceFlagHelpOutput(t *testing.T) {
|
||||||
@ -630,9 +630,9 @@ var intSliceFlagTests = []struct {
|
|||||||
value *IntSlice
|
value *IntSlice
|
||||||
expected string
|
expected string
|
||||||
}{
|
}{
|
||||||
{"heads", nil, NewIntSlice(), "--heads value\t"},
|
{"heads", nil, NewIntSlice(), "--heads value\t(accepts multiple inputs)"},
|
||||||
{"H", nil, NewIntSlice(), "-H value\t"},
|
{"H", nil, NewIntSlice(), "-H value\t(accepts multiple inputs)"},
|
||||||
{"H", []string{"heads"}, NewIntSlice(9, 3), "-H value, --heads value\t(default: 9, 3)"},
|
{"H", []string{"heads"}, NewIntSlice(9, 3), "-H value, --heads value\t(default: 9, 3)\t(accepts multiple inputs)"},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestIntSliceFlagHelpOutput(t *testing.T) {
|
func TestIntSliceFlagHelpOutput(t *testing.T) {
|
||||||
@ -719,10 +719,10 @@ var int64SliceFlagTests = []struct {
|
|||||||
value *Int64Slice
|
value *Int64Slice
|
||||||
expected string
|
expected string
|
||||||
}{
|
}{
|
||||||
{"heads", nil, NewInt64Slice(), "--heads value\t"},
|
{"heads", nil, NewInt64Slice(), "--heads value\t(accepts multiple inputs)"},
|
||||||
{"H", nil, NewInt64Slice(), "-H value\t"},
|
{"H", nil, NewInt64Slice(), "-H value\t(accepts multiple inputs)"},
|
||||||
{"heads", []string{"H"}, NewInt64Slice(int64(2), int64(17179869184)),
|
{"heads", []string{"H"}, NewInt64Slice(int64(2), int64(17179869184)),
|
||||||
"--heads value, -H value\t(default: 2, 17179869184)"},
|
"--heads value, -H value\t(default: 2, 17179869184)\t(accepts multiple inputs)"},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestInt64SliceFlagHelpOutput(t *testing.T) {
|
func TestInt64SliceFlagHelpOutput(t *testing.T) {
|
||||||
@ -864,10 +864,10 @@ var float64SliceFlagTests = []struct {
|
|||||||
value *Float64Slice
|
value *Float64Slice
|
||||||
expected string
|
expected string
|
||||||
}{
|
}{
|
||||||
{"heads", nil, NewFloat64Slice(), "--heads value\t"},
|
{"heads", nil, NewFloat64Slice(), "--heads value\t(accepts multiple inputs)"},
|
||||||
{"H", nil, NewFloat64Slice(), "-H value\t"},
|
{"H", nil, NewFloat64Slice(), "-H value\t(accepts multiple inputs)"},
|
||||||
{"heads", []string{"H"}, NewFloat64Slice(0.1234, -10.5),
|
{"heads", []string{"H"}, NewFloat64Slice(0.1234, -10.5),
|
||||||
"--heads value, -H value\t(default: 0.1234, -10.5)"},
|
"--heads value, -H value\t(default: 0.1234, -10.5)\t(accepts multiple inputs)"},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFloat64SliceFlagHelpOutput(t *testing.T) {
|
func TestFloat64SliceFlagHelpOutput(t *testing.T) {
|
||||||
|
Loading…
Reference in New Issue
Block a user