From 84a91cabdd6d857e4aee7b86fcca97a1a4425a64 Mon Sep 17 00:00:00 2001 From: Victor Vieux Date: Fri, 31 Jan 2014 11:33:48 -0800 Subject: [PATCH] fix panic in mflag Docker-DCO-1.1-Signed-off-by: Victor Vieux (github: vieux) --- mflag/example/example.go | 13 ++++++++----- mflag/flag.go | 5 +++++ mflag/flag_test.go | 16 ++++++++++++++++ 3 files changed, 29 insertions(+), 5 deletions(-) diff --git a/mflag/example/example.go b/mflag/example/example.go index 543592d..fa26c97 100644 --- a/mflag/example/example.go +++ b/mflag/example/example.go @@ -6,13 +6,14 @@ import ( ) var ( - i int - str string - b, h bool + i int + str string + b, b2, h bool ) func init() { flag.BoolVar(&b, []string{"b"}, false, "a simple bool") + flag.BoolVar(&b2, []string{"-bool"}, false, "a simple bool") flag.IntVar(&i, []string{"#integer", "-integer"}, -1, "a simple integer") flag.StringVar(&str, []string{"s", "#hidden", "-string"}, "", "a simple string") //-s -hidden and --string will work, but -hidden won't be in the usage flag.BoolVar(&h, []string{"h", "#help", "-help"}, false, "display the help") @@ -22,6 +23,8 @@ func main() { if h { flag.PrintDefaults() } - fmt.Printf("%s\n", str) - fmt.Printf("%s\n", flag.Lookup("s").Value.String()) + fmt.Printf("s/#hidden/-string: %s\n", str) + fmt.Printf("b: %b\n", b) + fmt.Printf("-bool: %b\n", b2) + fmt.Printf("s/#hidden/-string(via lookup): %s\n", flag.Lookup("s").Value.String()) } diff --git a/mflag/flag.go b/mflag/flag.go index 8e22c0e..f721e04 100644 --- a/mflag/flag.go +++ b/mflag/flag.go @@ -287,6 +287,11 @@ type Flag struct { func sortFlags(flags map[string]*Flag) []*Flag { var list sort.StringSlice for _, f := range flags { + if len(f.Names) == 1 { + list = append(list, f.Names[0]) + continue + } + found := false fName := strings.TrimPrefix(strings.TrimPrefix(f.Names[0], "#"), "-") for _, name := range list { diff --git a/mflag/flag_test.go b/mflag/flag_test.go index 631febc..b9e8a0e 100644 --- a/mflag/flag_test.go +++ b/mflag/flag_test.go @@ -228,6 +228,22 @@ func testParse(f *FlagSet, t *testing.T) { } } +func testPanic(f *FlagSet, t *testing.T) { + f.Int([]string{"-int"}, 0, "int value") + if f.Parsed() { + t.Error("f.Parse() = true before Parse") + } + args := []string{ + "-int", "21", + } + f.Parse(args) +} + +func TestParsePanic(t *testing.T) { + ResetForTesting(func() {}) + testPanic(CommandLine, t) +} + func TestParse(t *testing.T) { ResetForTesting(func() { t.Error("bad parse") }) testParse(CommandLine, t)