2018-01-13 00:30:54 +08:00
|
|
|
// Package flags contains enahnced versions of spf13/pflag flag
|
|
|
|
// routines which will read from the environment also.
|
|
|
|
package flags
|
2016-12-20 23:50:46 +08:00
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
"os"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
|
2018-01-13 00:30:54 +08:00
|
|
|
"github.com/ncw/rclone/fs"
|
2016-12-20 23:50:46 +08:00
|
|
|
"github.com/spf13/pflag"
|
|
|
|
)
|
|
|
|
|
|
|
|
// optionToEnv converts an option name, eg "ignore-size" into an
|
|
|
|
// environment name "RCLONE_IGNORE_SIZE"
|
|
|
|
func optionToEnv(name string) string {
|
|
|
|
return "RCLONE_" + strings.ToUpper(strings.Replace(name, "-", "_", -1))
|
|
|
|
}
|
|
|
|
|
|
|
|
// setDefaultFromEnv constructs a name from the flag passed in and
|
|
|
|
// sets the default from the environment if possible.
|
|
|
|
func setDefaultFromEnv(name string) {
|
|
|
|
key := optionToEnv(name)
|
|
|
|
newValue, found := os.LookupEnv(key)
|
|
|
|
if found {
|
|
|
|
flag := pflag.Lookup(name)
|
|
|
|
if flag == nil {
|
|
|
|
log.Fatalf("Couldn't find flag %q", name)
|
|
|
|
}
|
|
|
|
err := flag.Value.Set(newValue)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("Invalid value for environment variable %q: %v", key, err)
|
|
|
|
}
|
2018-01-13 00:30:54 +08:00
|
|
|
fs.Debugf(nil, "Set default for %q from %q to %q (%v)", name, key, newValue, flag.Value)
|
2016-12-20 23:50:46 +08:00
|
|
|
flag.DefValue = newValue
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// StringP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.StringP
|
|
|
|
func StringP(name, shorthand string, value string, usage string) (out *string) {
|
|
|
|
out = pflag.StringP(name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
return out
|
|
|
|
}
|
|
|
|
|
2017-11-08 01:09:08 +08:00
|
|
|
// StringVarP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.StringVarP
|
|
|
|
func StringVarP(flags *pflag.FlagSet, p *string, name, shorthand string, value string, usage string) {
|
|
|
|
flags.StringVarP(p, name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
}
|
|
|
|
|
2016-12-20 23:50:46 +08:00
|
|
|
// BoolP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.BoolP
|
|
|
|
func BoolP(name, shorthand string, value bool, usage string) (out *bool) {
|
|
|
|
out = pflag.BoolP(name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
return out
|
|
|
|
}
|
|
|
|
|
2017-11-08 01:09:08 +08:00
|
|
|
// BoolVarP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.BoolVarP
|
|
|
|
func BoolVarP(flags *pflag.FlagSet, p *bool, name, shorthand string, value bool, usage string) {
|
|
|
|
flags.BoolVarP(p, name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
}
|
|
|
|
|
2016-12-20 23:50:46 +08:00
|
|
|
// IntP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.IntP
|
|
|
|
func IntP(name, shorthand string, value int, usage string) (out *int) {
|
|
|
|
out = pflag.IntP(name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
return out
|
|
|
|
}
|
|
|
|
|
2018-01-13 00:30:54 +08:00
|
|
|
// Int64P defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.IntP
|
|
|
|
func Int64P(name, shorthand string, value int64, usage string) (out *int64) {
|
|
|
|
out = pflag.Int64P(name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
return out
|
|
|
|
}
|
|
|
|
|
2018-01-23 02:53:18 +08:00
|
|
|
// IntVar64P defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.Int64VarP
|
|
|
|
func IntVar64P(flags *pflag.FlagSet, p *int64, name, shorthand string, value int64, usage string) {
|
|
|
|
flags.Int64VarP(p, name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
}
|
|
|
|
|
2017-11-08 01:09:08 +08:00
|
|
|
// IntVarP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.IntVarP
|
|
|
|
func IntVarP(flags *pflag.FlagSet, p *int, name, shorthand string, value int, usage string) {
|
|
|
|
flags.IntVarP(p, name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Uint32VarP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.Uint32VarP
|
|
|
|
func Uint32VarP(flags *pflag.FlagSet, p *uint32, name, shorthand string, value uint32, usage string) {
|
|
|
|
flags.Uint32VarP(p, name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
}
|
|
|
|
|
2017-07-13 12:11:24 +08:00
|
|
|
// Float64P defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.Float64P
|
|
|
|
func Float64P(name, shorthand string, value float64, usage string) (out *float64) {
|
|
|
|
out = pflag.Float64P(name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
return out
|
|
|
|
}
|
|
|
|
|
2017-11-08 01:09:08 +08:00
|
|
|
// Float64VarP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.Float64VarP
|
|
|
|
func Float64VarP(flags *pflag.FlagSet, p *float64, name, shorthand string, value float64, usage string) {
|
|
|
|
flags.Float64VarP(p, name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
}
|
|
|
|
|
2016-12-20 23:50:46 +08:00
|
|
|
// DurationP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.DurationP
|
|
|
|
func DurationP(name, shorthand string, value time.Duration, usage string) (out *time.Duration) {
|
|
|
|
out = pflag.DurationP(name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
return out
|
|
|
|
}
|
|
|
|
|
2017-11-08 01:09:08 +08:00
|
|
|
// DurationVarP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.DurationVarP
|
|
|
|
func DurationVarP(flags *pflag.FlagSet, p *time.Duration, name, shorthand string, value time.Duration, usage string) {
|
|
|
|
flags.DurationVarP(p, name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
}
|
|
|
|
|
2016-12-20 23:50:46 +08:00
|
|
|
// VarP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.VarP
|
|
|
|
func VarP(value pflag.Value, name, shorthand, usage string) {
|
|
|
|
pflag.VarP(value, name, shorthand, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
}
|
|
|
|
|
2018-01-13 00:30:54 +08:00
|
|
|
// FVarP defines a flag which can be overridden by an environment variable
|
2017-11-08 01:09:08 +08:00
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.VarP
|
2018-01-13 00:30:54 +08:00
|
|
|
func FVarP(flags *pflag.FlagSet, value pflag.Value, name, shorthand, usage string) {
|
2017-11-08 01:09:08 +08:00
|
|
|
flags.VarP(value, name, shorthand, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
}
|
|
|
|
|
2016-12-20 23:50:46 +08:00
|
|
|
// StringArrayP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It sets one value only - command line flags can be used to set more.
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.StringArrayP
|
|
|
|
func StringArrayP(name, shorthand string, value []string, usage string) (out *[]string) {
|
|
|
|
out = pflag.StringArrayP(name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
return out
|
|
|
|
}
|
2017-02-10 05:22:46 +08:00
|
|
|
|
2017-11-08 01:09:08 +08:00
|
|
|
// StringArrayVarP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It sets one value only - command line flags can be used to set more.
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.StringArrayVarP
|
|
|
|
func StringArrayVarP(flags *pflag.FlagSet, p *[]string, name, shorthand string, value []string, usage string) {
|
|
|
|
flags.StringArrayVarP(p, name, shorthand, value, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
}
|
|
|
|
|
2017-02-10 05:22:46 +08:00
|
|
|
// CountP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.CountP
|
|
|
|
func CountP(name, shorthand string, usage string) (out *int) {
|
|
|
|
out = pflag.CountP(name, shorthand, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
return out
|
|
|
|
}
|
2017-11-08 01:09:08 +08:00
|
|
|
|
|
|
|
// CountVarP defines a flag which can be overridden by an environment variable
|
|
|
|
//
|
|
|
|
// It is a thin wrapper around pflag.CountVarP
|
|
|
|
func CountVarP(flags *pflag.FlagSet, p *int, name, shorthand string, usage string) {
|
|
|
|
flags.CountVarP(p, name, shorthand, usage)
|
|
|
|
setDefaultFromEnv(name)
|
|
|
|
}
|