bsc/ethutil/config.go

68 lines
1.5 KiB
Go
Raw Normal View History

2014-02-15 00:56:09 +02:00
package ethutil
import (
2014-05-30 20:51:19 +03:00
"flag"
"fmt"
"os"
2014-07-26 12:24:44 +03:00
"github.com/rakyll/globalconf"
2014-02-15 00:56:09 +02:00
)
// Config struct
type ConfigManager struct {
ExecPath string
Debug bool
2014-07-11 17:04:09 +03:00
Diff bool
2014-07-14 01:37:50 +03:00
DiffType string
Paranoia bool
VmType int
2014-05-30 20:51:19 +03:00
conf *globalconf.GlobalConf
2014-02-15 00:56:09 +02:00
}
// Read config
//
// Initialize Config from Config File
func ReadConfig(ConfigFile string, Datadir string, EnvPrefix string) *ConfigManager {
if !FileExist(ConfigFile) {
// create ConfigFile if it does not exist, otherwise
// globalconf will panic when trying to persist flags.
fmt.Printf("config file '%s' doesn't exist, creating it\n", ConfigFile)
os.Create(ConfigFile)
}
g, err := globalconf.NewWithOptions(&globalconf.Options{
Filename: ConfigFile,
EnvPrefix: EnvPrefix,
})
if err != nil {
fmt.Println(err)
} else {
g.ParseAll()
2014-02-15 00:56:09 +02:00
}
cfg := &ConfigManager{ExecPath: Datadir, Debug: true, conf: g, Paranoia: true}
return cfg
2014-02-15 00:56:09 +02:00
}
// provides persistence for flags
func (c *ConfigManager) Save(key string, value interface{}) {
f := &flag.Flag{Name: key, Value: newConfValue(value)}
2014-05-30 20:51:19 +03:00
c.conf.Set("", f)
}
func (c *ConfigManager) Delete(key string) {
c.conf.Delete("", key)
}
// private type implementing flag.Value
2014-05-30 20:51:19 +03:00
type confValue struct {
value string
}
// generic constructor to allow persising non-string values directly
func newConfValue(value interface{}) *confValue {
return &confValue{fmt.Sprintf("%v", value)}
}
2014-05-30 20:51:19 +03:00
func (self confValue) String() string { return self.value }
func (self confValue) Set(s string) error { self.value = s; return nil }