| package pflag |
| |
| import ( |
| "fmt" |
| "strings" |
| "time" |
| ) |
| |
| // TimeValue adapts time.Time for use as a flag. |
| type timeValue struct { |
| *time.Time |
| formats []string |
| } |
| |
| func newTimeValue(val time.Time, p *time.Time, formats []string) *timeValue { |
| *p = val |
| return &timeValue{ |
| Time: p, |
| formats: formats, |
| } |
| } |
| |
| // Set time.Time value from string based on accepted formats. |
| func (d *timeValue) Set(s string) error { |
| s = strings.TrimSpace(s) |
| for _, f := range d.formats { |
| v, err := time.Parse(f, s) |
| if err != nil { |
| continue |
| } |
| *d.Time = v |
| return nil |
| } |
| |
| formatsString := "" |
| for i, f := range d.formats { |
| if i > 0 { |
| formatsString += ", " |
| } |
| formatsString += fmt.Sprintf("`%s`", f) |
| } |
| |
| return fmt.Errorf("invalid time format `%s` must be one of: %s", s, formatsString) |
| } |
| |
| // Type name for time.Time flags. |
| func (d *timeValue) Type() string { |
| return "time" |
| } |
| |
| func (d *timeValue) String() string { |
| if d.Time.IsZero() { |
| return "" |
| } else { |
| return d.Time.Format(time.RFC3339Nano) |
| } |
| } |
| |
| // GetTime return the time value of a flag with the given name |
| func (f *FlagSet) GetTime(name string) (time.Time, error) { |
| flag := f.Lookup(name) |
| if flag == nil { |
| err := fmt.Errorf("flag accessed but not defined: %s", name) |
| return time.Time{}, err |
| } |
| |
| if flag.Value.Type() != "time" { |
| err := fmt.Errorf("trying to get %s value of flag of type %s", "time", flag.Value.Type()) |
| return time.Time{}, err |
| } |
| |
| val, ok := flag.Value.(*timeValue) |
| if !ok { |
| return time.Time{}, fmt.Errorf("value %s is not a time", flag.Value) |
| } |
| |
| return *val.Time, nil |
| } |
| |
| // TimeVar defines a time.Time flag with specified name, default value, and usage string. |
| // The argument p points to a time.Time variable in which to store the value of the flag. |
| func (f *FlagSet) TimeVar(p *time.Time, name string, value time.Time, formats []string, usage string) { |
| f.TimeVarP(p, name, "", value, formats, usage) |
| } |
| |
| // TimeVarP is like TimeVar, but accepts a shorthand letter that can be used after a single dash. |
| func (f *FlagSet) TimeVarP(p *time.Time, name, shorthand string, value time.Time, formats []string, usage string) { |
| f.VarP(newTimeValue(value, p, formats), name, shorthand, usage) |
| } |
| |
| // TimeVar defines a time.Time flag with specified name, default value, and usage string. |
| // The argument p points to a time.Time variable in which to store the value of the flag. |
| func TimeVar(p *time.Time, name string, value time.Time, formats []string, usage string) { |
| CommandLine.TimeVarP(p, name, "", value, formats, usage) |
| } |
| |
| // TimeVarP is like TimeVar, but accepts a shorthand letter that can be used after a single dash. |
| func TimeVarP(p *time.Time, name, shorthand string, value time.Time, formats []string, usage string) { |
| CommandLine.VarP(newTimeValue(value, p, formats), name, shorthand, usage) |
| } |
| |
| // Time defines a time.Time flag with specified name, default value, and usage string. |
| // The return value is the address of a time.Time variable that stores the value of the flag. |
| func (f *FlagSet) Time(name string, value time.Time, formats []string, usage string) *time.Time { |
| return f.TimeP(name, "", value, formats, usage) |
| } |
| |
| // TimeP is like Time, but accepts a shorthand letter that can be used after a single dash. |
| func (f *FlagSet) TimeP(name, shorthand string, value time.Time, formats []string, usage string) *time.Time { |
| p := new(time.Time) |
| f.TimeVarP(p, name, shorthand, value, formats, usage) |
| return p |
| } |
| |
| // Time defines a time.Time flag with specified name, default value, and usage string. |
| // The return value is the address of a time.Time variable that stores the value of the flag. |
| func Time(name string, value time.Time, formats []string, usage string) *time.Time { |
| return CommandLine.TimeP(name, "", value, formats, usage) |
| } |
| |
| // TimeP is like Time, but accepts a shorthand letter that can be used after a single dash. |
| func TimeP(name, shorthand string, value time.Time, formats []string, usage string) *time.Time { |
| return CommandLine.TimeP(name, shorthand, value, formats, usage) |
| } |