forked from cornfeedhobo/pflag
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathstring_to_int64.go
113 lines (93 loc) · 3.43 KB
/
string_to_int64.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package zflag
import (
"fmt"
"strconv"
"strings"
)
// -- stringToInt64 Value
type stringToInt64Value struct {
value *map[string]int64
changed bool
valueOptional bool
}
var _ Value = (*stringToInt64Value)(nil)
var _ Getter = (*stringToInt64Value)(nil)
var _ Typed = (*stringToInt64Value)(nil)
func newStringToInt64Value(val map[string]int64, p *map[string]int64) *stringToInt64Value {
ssv := new(stringToInt64Value)
ssv.value = p
*ssv.value = val
return ssv
}
// Format: a=1,b=2
func (s *stringToInt64Value) Set(val string) error {
kv := strings.SplitN(val, "=", 2)
if len(kv) != 2 {
return fmt.Errorf("%s must be formatted as key=value", val)
}
key, val := kv[0], kv[1]
val = strings.TrimSpace(val)
v, err := strconv.ParseInt(val, 10, 64)
if err != nil {
return err
}
if !s.changed {
*s.value = map[string]int64{}
}
(*s.value)[key] = v
s.changed = true
return nil
}
func (s *stringToInt64Value) Get() interface{} {
return *s.value
}
func (s *stringToInt64Value) Type() string {
return "stringToInt64"
}
func (s *stringToInt64Value) String() string {
records := make([]string, 0, len(*s.value)>>1)
for k, v := range *s.value {
records = append(records, k+"="+strconv.FormatInt(v, 10))
}
return fmt.Sprintf("%s", records)
}
// GetStringToInt64 return the map[string]int64 value of a flag with the given name
func (fs *FlagSet) GetStringToInt64(name string) (map[string]int64, error) {
val, err := fs.getFlagValue(name, "stringToInt64")
if err != nil {
return map[string]int64{}, err
}
return val.(map[string]int64), nil
}
// MustGetStringToInt64 is like GetStringToInt64, but panics on error.
func (fs *FlagSet) MustGetStringToInt64(name string) map[string]int64 {
val, err := fs.GetStringToInt64(name)
if err != nil {
panic(err)
}
return val
}
// StringToInt64Var defines a map[string]int64 flag with specified name, default value, and usage string.
// The argument p points to a map[string]int64 variable in which to store the values of multiple flags.
func (fs *FlagSet) StringToInt64Var(p *map[string]int64, name string, value map[string]int64, usage string, opts ...Opt) {
fs.Var(newStringToInt64Value(value, p), name, usage, opts...)
}
// StringToInt64Var defines a map[string]int64 flag with specified name, default value, and usage string.
// The argument p points to a map[string]int64 variable in which to store the values of multiple flags.
func StringToInt64Var(p *map[string]int64, name string, value map[string]int64, usage string, opts ...Opt) {
CommandLine.StringToInt64Var(p, name, value, usage, opts...)
}
// StringToInt64 defines a map[string]int64 flag with specified name, default value, and usage string.
// The return value is the address of a map[string]int64 variable that stores the values of multiple flags.
func (fs *FlagSet) StringToInt64(name string, value map[string]int64, usage string, opts ...Opt) *map[string]int64 {
var p map[string]int64
fs.StringToInt64Var(&p, name, value, usage, opts...)
return &p
}
// StringToInt64 defines a map[string]int64 flag with specified name, default value, and usage string.
// The return value is the address of a map[string]int64 variable that stores the values of multiple flags.
func StringToInt64(name string, value map[string]int64, usage string, opts ...Opt) *map[string]int64 {
return CommandLine.StringToInt64(name, value, usage, opts...)
}