dont clobber slices with envvar

Signed-off-by: Joshua Rubin <jrubin@zvelo.com>
This commit is contained in:
Joshua Rubin 2017-11-21 15:21:31 -07:00
parent 7ace96b43d
commit 37b7abb1c4
No known key found for this signature in database
GPG Key ID: 7E86D83E7AD27F82

18
flag.go
View File

@ -178,7 +178,11 @@ func (f StringSliceFlag) ApplyWithError(set *flag.FlagSet) error {
return fmt.Errorf("could not parse %s as string value for flag %s: %s", envVal, f.Name, err) return fmt.Errorf("could not parse %s as string value for flag %s: %s", envVal, f.Name, err)
} }
} }
f.Value = newVal if f.Value == nil {
f.Value = newVal
} else {
*f.Value = *newVal
}
} }
eachName(f.Name, func(name string) { eachName(f.Name, func(name string) {
@ -235,7 +239,11 @@ func (f IntSliceFlag) ApplyWithError(set *flag.FlagSet) error {
return fmt.Errorf("could not parse %s as int slice value for flag %s: %s", envVal, f.Name, err) return fmt.Errorf("could not parse %s as int slice value for flag %s: %s", envVal, f.Name, err)
} }
} }
f.Value = newVal if f.Value == nil {
f.Value = newVal
} else {
*f.Value = *newVal
}
} }
eachName(f.Name, func(name string) { eachName(f.Name, func(name string) {
@ -292,7 +300,11 @@ func (f Int64SliceFlag) ApplyWithError(set *flag.FlagSet) error {
return fmt.Errorf("could not parse %s as int64 slice value for flag %s: %s", envVal, f.Name, err) return fmt.Errorf("could not parse %s as int64 slice value for flag %s: %s", envVal, f.Name, err)
} }
} }
f.Value = newVal if f.Value == nil {
f.Value = newVal
} else {
*f.Value = *newVal
}
} }
eachName(f.Name, func(name string) { eachName(f.Name, func(name string) {