summaryrefslogtreecommitdiff
path: root/cmd/podman/validate/choice.go
diff options
context:
space:
mode:
authorOpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com>2020-04-30 20:01:55 +0200
committerGitHub <noreply@github.com>2020-04-30 20:01:55 +0200
commit6900517f109d78ed5a9b794666b7d97782cf6ce9 (patch)
tree05e08e081bd03d23943dd255fabdcafe8b83147d /cmd/podman/validate/choice.go
parentfc9451ed15e3ea2fbdcd5754b367db74eec1063e (diff)
parent22d5b2e3053ad66ce3b30eba3adfca70bc8e389d (diff)
downloadpodman-6900517f109d78ed5a9b794666b7d97782cf6ce9.tar.gz
podman-6900517f109d78ed5a9b794666b7d97782cf6ce9.tar.bz2
podman-6900517f109d78ed5a9b794666b7d97782cf6ce9.zip
Merge pull request #6046 from jwhonce/jira/822
V2 enable ps tests
Diffstat (limited to 'cmd/podman/validate/choice.go')
-rw-r--r--cmd/podman/validate/choice.go46
1 files changed, 46 insertions, 0 deletions
diff --git a/cmd/podman/validate/choice.go b/cmd/podman/validate/choice.go
new file mode 100644
index 000000000..572c5f4a5
--- /dev/null
+++ b/cmd/podman/validate/choice.go
@@ -0,0 +1,46 @@
+package validate
+
+import (
+ "fmt"
+ "strings"
+)
+
+// Honors cobra.Value interface
+type choiceValue struct {
+ value *string
+ choices []string
+}
+
+// ChoiceValue may be used in cobra FlagSet methods Var/VarP/VarPF() to select from a set of values
+//
+// Example:
+// created := validate.ChoiceValue(&opts.Sort, "command", "created", "id", "image", "names", "runningfor", "size", "status")
+// flags.Var(created, "sort", "Sort output by: "+created.Choices())
+func ChoiceValue(p *string, choices ...string) *choiceValue {
+ return &choiceValue{
+ value: p,
+ choices: choices,
+ }
+}
+
+func (c *choiceValue) String() string {
+ return *c.value
+}
+
+func (c *choiceValue) Set(value string) error {
+ for _, v := range c.choices {
+ if v == value {
+ *c.value = value
+ return nil
+ }
+ }
+ return fmt.Errorf("%q is not a valid value. Choose from: %q", value, c.Choices())
+}
+
+func (c *choiceValue) Choices() string {
+ return strings.Join(c.choices, ", ")
+}
+
+func (c *choiceValue) Type() string {
+ return "choice"
+}