forked from cornfeedhobo/pflag
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbool_slice.go
146 lines (123 loc) · 3.86 KB
/
bool_slice.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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
// 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"
)
// -- boolSlice Value
type boolSliceValue struct {
value *[]bool
changed bool
}
var _ Value = (*boolSliceValue)(nil)
var _ Getter = (*boolSliceValue)(nil)
var _ SliceValue = (*boolSliceValue)(nil)
var _ Typed = (*boolSliceValue)(nil)
func newBoolSliceValue(val []bool, p *[]bool) *boolSliceValue {
bsv := new(boolSliceValue)
bsv.value = p
*bsv.value = val
return bsv
}
// Set converts, and assigns, the boolean argument string representation as the []bool value of this flag.
// If Set is called on a flag that already has a []bool assigned, the newly converted values will be appended.
func (s *boolSliceValue) Set(val string) error {
val = strings.TrimSpace(val)
b, err := strconv.ParseBool(val)
if err != nil {
return err
}
if !s.changed {
*s.value = []bool{}
}
*s.value = append(*s.value, b)
s.changed = true
return nil
}
func (s *boolSliceValue) Get() interface{} {
return *s.value
}
// Type returns a string that uniquely represents this flag's type.
func (s *boolSliceValue) Type() string {
return "boolSlice"
}
// String defines a "native" format for this boolean slice flag value.
func (s *boolSliceValue) String() string {
if s.value == nil || *s.value == nil {
return "[]"
}
return fmt.Sprintf("%t", *s.value)
}
func (s *boolSliceValue) fromString(val string) (bool, error) {
return strconv.ParseBool(val)
}
func (s *boolSliceValue) toString(val bool) string {
return strconv.FormatBool(val)
}
func (s *boolSliceValue) Append(val string) error {
i, err := s.fromString(val)
if err != nil {
return err
}
*s.value = append(*s.value, i)
return nil
}
func (s *boolSliceValue) Replace(val []string) error {
out := make([]bool, len(val))
for i, d := range val {
var err error
out[i], err = s.fromString(d)
if err != nil {
return err
}
}
*s.value = out
return nil
}
func (s *boolSliceValue) GetSlice() []string {
out := make([]string, len(*s.value))
for i, d := range *s.value {
out[i] = s.toString(d)
}
return out
}
// GetBoolSlice returns the []bool value of a flag with the given name.
func (fs *FlagSet) GetBoolSlice(name string) ([]bool, error) {
val, err := fs.getFlagValue(name, "boolSlice")
if err != nil {
return []bool{}, err
}
return val.([]bool), nil
}
// MustGetBoolSlice is like GetBoolSlice, but panics on error.
func (fs *FlagSet) MustGetBoolSlice(name string) []bool {
val, err := fs.GetBoolSlice(name)
if err != nil {
panic(err)
}
return val
}
// BoolSliceVar defines a boolSlice flag with specified name, default value, and usage string.
// The argument p points to a []bool variable in which to store the value of the flag.
func (fs *FlagSet) BoolSliceVar(p *[]bool, name string, value []bool, usage string, opts ...Opt) {
fs.Var(newBoolSliceValue(value, p), name, usage, opts...)
}
// BoolSliceVar defines a []bool flag with specified name, default value, and usage string.
// The argument p points to a []bool variable in which to store the value of the flag.
func BoolSliceVar(p *[]bool, name string, value []bool, usage string, opts ...Opt) {
CommandLine.BoolSliceVar(p, name, value, usage, opts...)
}
// BoolSlice defines a []bool flag with specified name, default value, and usage string.
// The return value is the address of a []bool variable that stores the value of the flag.
func (fs *FlagSet) BoolSlice(name string, value []bool, usage string, opts ...Opt) *[]bool {
var p []bool
fs.BoolSliceVar(&p, name, value, usage, opts...)
return &p
}
// BoolSlice defines a []bool flag with specified name, default value, and usage string.
// The return value is the address of a []bool variable that stores the value of the flag.
func BoolSlice(name string, value []bool, usage string, opts ...Opt) *[]bool {
return CommandLine.BoolSlice(name, value, usage, opts...)
}