Path: blob/main/vendor/github.com/spf13/pflag/string_slice.go
2875 views
package pflag12import (3"bytes"4"encoding/csv"5"strings"6)78// -- stringSlice Value9type stringSliceValue struct {10value *[]string11changed bool12}1314func newStringSliceValue(val []string, p *[]string) *stringSliceValue {15ssv := new(stringSliceValue)16ssv.value = p17*ssv.value = val18return ssv19}2021func readAsCSV(val string) ([]string, error) {22if val == "" {23return []string{}, nil24}25stringReader := strings.NewReader(val)26csvReader := csv.NewReader(stringReader)27return csvReader.Read()28}2930func writeAsCSV(vals []string) (string, error) {31b := &bytes.Buffer{}32w := csv.NewWriter(b)33err := w.Write(vals)34if err != nil {35return "", err36}37w.Flush()38return strings.TrimSuffix(b.String(), "\n"), nil39}4041func (s *stringSliceValue) Set(val string) error {42v, err := readAsCSV(val)43if err != nil {44return err45}46if !s.changed {47*s.value = v48} else {49*s.value = append(*s.value, v...)50}51s.changed = true52return nil53}5455func (s *stringSliceValue) Type() string {56return "stringSlice"57}5859func (s *stringSliceValue) String() string {60str, _ := writeAsCSV(*s.value)61return "[" + str + "]"62}6364func (s *stringSliceValue) Append(val string) error {65*s.value = append(*s.value, val)66return nil67}6869func (s *stringSliceValue) Replace(val []string) error {70*s.value = val71return nil72}7374func (s *stringSliceValue) GetSlice() []string {75return *s.value76}7778func stringSliceConv(sval string) (interface{}, error) {79sval = sval[1 : len(sval)-1]80// An empty string would cause a slice with one (empty) string81if len(sval) == 0 {82return []string{}, nil83}84return readAsCSV(sval)85}8687// GetStringSlice return the []string value of a flag with the given name88func (f *FlagSet) GetStringSlice(name string) ([]string, error) {89val, err := f.getFlagType(name, "stringSlice", stringSliceConv)90if err != nil {91return []string{}, err92}93return val.([]string), nil94}9596// StringSliceVar defines a string flag with specified name, default value, and usage string.97// The argument p points to a []string variable in which to store the value of the flag.98// Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly.99// For example:100// --ss="v1,v2" --ss="v3"101// will result in102// []string{"v1", "v2", "v3"}103func (f *FlagSet) StringSliceVar(p *[]string, name string, value []string, usage string) {104f.VarP(newStringSliceValue(value, p), name, "", usage)105}106107// StringSliceVarP is like StringSliceVar, but accepts a shorthand letter that can be used after a single dash.108func (f *FlagSet) StringSliceVarP(p *[]string, name, shorthand string, value []string, usage string) {109f.VarP(newStringSliceValue(value, p), name, shorthand, usage)110}111112// StringSliceVar defines a string flag with specified name, default value, and usage string.113// The argument p points to a []string variable in which to store the value of the flag.114// Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly.115// For example:116// --ss="v1,v2" --ss="v3"117// will result in118// []string{"v1", "v2", "v3"}119func StringSliceVar(p *[]string, name string, value []string, usage string) {120CommandLine.VarP(newStringSliceValue(value, p), name, "", usage)121}122123// StringSliceVarP is like StringSliceVar, but accepts a shorthand letter that can be used after a single dash.124func StringSliceVarP(p *[]string, name, shorthand string, value []string, usage string) {125CommandLine.VarP(newStringSliceValue(value, p), name, shorthand, usage)126}127128// StringSlice defines a string flag with specified name, default value, and usage string.129// The return value is the address of a []string variable that stores the value of the flag.130// Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly.131// For example:132// --ss="v1,v2" --ss="v3"133// will result in134// []string{"v1", "v2", "v3"}135func (f *FlagSet) StringSlice(name string, value []string, usage string) *[]string {136p := []string{}137f.StringSliceVarP(&p, name, "", value, usage)138return &p139}140141// StringSliceP is like StringSlice, but accepts a shorthand letter that can be used after a single dash.142func (f *FlagSet) StringSliceP(name, shorthand string, value []string, usage string) *[]string {143p := []string{}144f.StringSliceVarP(&p, name, shorthand, value, usage)145return &p146}147148// StringSlice defines a string flag with specified name, default value, and usage string.149// The return value is the address of a []string variable that stores the value of the flag.150// Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly.151// For example:152// --ss="v1,v2" --ss="v3"153// will result in154// []string{"v1", "v2", "v3"}155func StringSlice(name string, value []string, usage string) *[]string {156return CommandLine.StringSliceP(name, "", value, usage)157}158159// StringSliceP is like StringSlice, but accepts a shorthand letter that can be used after a single dash.160func StringSliceP(name, shorthand string, value []string, usage string) *[]string {161return CommandLine.StringSliceP(name, shorthand, value, usage)162}163164165