...
1
16
17 package flag
18
19 import (
20 "fmt"
21 "sort"
22 "strings"
23 )
24
25
26
27
28 type LangleSeparatedMapStringString struct {
29 Map *map[string]string
30 initialized bool
31 }
32
33
34
35 func NewLangleSeparatedMapStringString(m *map[string]string) *LangleSeparatedMapStringString {
36 return &LangleSeparatedMapStringString{Map: m}
37 }
38
39
40 func (m *LangleSeparatedMapStringString) String() string {
41 pairs := []string{}
42 for k, v := range *m.Map {
43 pairs = append(pairs, fmt.Sprintf("%s<%s", k, v))
44 }
45 sort.Strings(pairs)
46 return strings.Join(pairs, ",")
47 }
48
49
50 func (m *LangleSeparatedMapStringString) Set(value string) error {
51 if m.Map == nil {
52 return fmt.Errorf("no target (nil pointer to map[string]string)")
53 }
54 if !m.initialized || *m.Map == nil {
55
56 *m.Map = make(map[string]string)
57 m.initialized = true
58 }
59 for _, s := range strings.Split(value, ",") {
60 if len(s) == 0 {
61 continue
62 }
63 arr := strings.SplitN(s, "<", 2)
64 if len(arr) != 2 {
65 return fmt.Errorf("malformed pair, expect string<string")
66 }
67 k := strings.TrimSpace(arr[0])
68 v := strings.TrimSpace(arr[1])
69 (*m.Map)[k] = v
70 }
71 return nil
72 }
73
74
75 func (*LangleSeparatedMapStringString) Type() string {
76 return "mapStringString"
77 }
78
79
80 func (m *LangleSeparatedMapStringString) Empty() bool {
81 return len(*m.Map) == 0
82 }
83
View as plain text