summaryrefslogtreecommitdiff
path: root/vendor/github.com/spf13/pflag/uint_slice.go
diff options
context:
space:
mode:
authorOpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com>2019-09-30 13:59:54 -0700
committerGitHub <noreply@github.com>2019-09-30 13:59:54 -0700
commitb063383390f8b23f69357d781784582e4d93c706 (patch)
tree86706e3405f01eccafd6af897784b7fe3e1c26ca /vendor/github.com/spf13/pflag/uint_slice.go
parent92a489bcdfcb16a8fa74f08b539696be2f6bd0ab (diff)
parentc245ef9d1b2322a35344bbf837baaf3892378bef (diff)
downloadpodman-b063383390f8b23f69357d781784582e4d93c706.tar.gz
podman-b063383390f8b23f69357d781784582e4d93c706.tar.bz2
podman-b063383390f8b23f69357d781784582e4d93c706.zip
Merge pull request #4144 from containers/dependabot/go_modules/github.com/spf13/pflag-1.0.5
Bump github.com/spf13/pflag from 1.0.3 to 1.0.5
Diffstat (limited to 'vendor/github.com/spf13/pflag/uint_slice.go')
-rw-r--r--vendor/github.com/spf13/pflag/uint_slice.go42
1 files changed, 42 insertions, 0 deletions
diff --git a/vendor/github.com/spf13/pflag/uint_slice.go b/vendor/github.com/spf13/pflag/uint_slice.go
index edd94c600..5fa924835 100644
--- a/vendor/github.com/spf13/pflag/uint_slice.go
+++ b/vendor/github.com/spf13/pflag/uint_slice.go
@@ -50,6 +50,48 @@ func (s *uintSliceValue) String() string {
return "[" + strings.Join(out, ",") + "]"
}
+func (s *uintSliceValue) fromString(val string) (uint, error) {
+ t, err := strconv.ParseUint(val, 10, 0)
+ if err != nil {
+ return 0, err
+ }
+ return uint(t), nil
+}
+
+func (s *uintSliceValue) toString(val uint) string {
+ return fmt.Sprintf("%d", val)
+}
+
+func (s *uintSliceValue) Append(val string) error {
+ i, err := s.fromString(val)
+ if err != nil {
+ return err
+ }
+ *s.value = append(*s.value, i)
+ return nil
+}
+
+func (s *uintSliceValue) Replace(val []string) error {
+ out := make([]uint, 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 *uintSliceValue) GetSlice() []string {
+ out := make([]string, len(*s.value))
+ for i, d := range *s.value {
+ out[i] = s.toString(d)
+ }
+ return out
+}
+
func uintSliceConv(val string) (interface{}, error) {
val = strings.Trim(val, "[]")
// Empty string would cause a slice with one (empty) entry