diff options
author | zelig <viktor.tron@gmail.com> | 2014-06-23 19:20:59 +0800 |
---|---|---|
committer | zelig <viktor.tron@gmail.com> | 2014-06-23 19:25:55 +0800 |
commit | 1024766514eea7bb628ec6e5ed974e997b8faefc (patch) | |
tree | 01b5846bd852822538e5010fe0c6116c6de900ea /ethereum/flags.go | |
parent | 456167aca0b795c625d6718ef8a06fe5fcb00c2e (diff) | |
download | go-tangerine-1024766514eea7bb628ec6e5ed974e997b8faefc.tar go-tangerine-1024766514eea7bb628ec6e5ed974e997b8faefc.tar.gz go-tangerine-1024766514eea7bb628ec6e5ed974e997b8faefc.tar.bz2 go-tangerine-1024766514eea7bb628ec6e5ed974e997b8faefc.tar.lz go-tangerine-1024766514eea7bb628ec6e5ed974e997b8faefc.tar.xz go-tangerine-1024766514eea7bb628ec6e5ed974e997b8faefc.tar.zst go-tangerine-1024766514eea7bb628ec6e5ed974e997b8faefc.zip |
refactor cli and gui wrapper code. Details:
- all cli functions shared between ethereum and ethereal abstracted to utils/ cmd.go (should be ethcommon or shared or sth)
- simplify main() now readable stepwise
- rename main wrapper files to main.go
- rename commmand line args definition file from config.go to flags.go
- rename Do -> Start to parallel option names
- register interrupt for rpc server stop
- fix interrupt stopping js repl and ethereum
- register interrupt for mining stop
- custom config file option from command line
- debug option from command line
- loglevel option from command line
- changed ethutil.Config API
- default datadir and default config file set together with other flag defaults in wrappers
- default assetpath set together with other command line flags defaults in gui wrapper (not in ethutil.Config or ui/ui_lib)
- options precedence: default < config file < environment variables < command line
Diffstat (limited to 'ethereum/flags.go')
-rw-r--r-- | ethereum/flags.go | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/ethereum/flags.go b/ethereum/flags.go new file mode 100644 index 000000000..513d93a6d --- /dev/null +++ b/ethereum/flags.go @@ -0,0 +1,72 @@ +package main + +import ( + "flag" + "fmt" + "os" + "os/user" + "path" + "github.com/ethereum/eth-go/ethlog" +) + +var Identifier string +var StartRpc bool +var RpcPort int +var UseUPnP bool +var OutboundPort string +var ShowGenesis bool +var AddPeer string +var MaxPeer int +var GenAddr bool +var UseSeed bool +var ImportKey string +var ExportKey bool +var NonInteractive bool +var Datadir string +var LogFile string +var ConfigFile string +var DebugFile string +var LogLevel int + +// flags specific to cli client +var StartMining bool +var StartJsConsole bool +var InputFile string + +func defaultDataDir() string { + usr, _ := user.Current() + return path.Join(usr.HomeDir, ".ethereum") +} + +var defaultConfigFile = path.Join(defaultDataDir(), "conf.ini") + +func Init() { + flag.Usage = func() { + fmt.Fprintf(os.Stderr, "%s [options] [filename]:\noptions precedence: default < config file < environment variables < command line", os.Args[0]) + flag.PrintDefaults() + } + + flag.StringVar(&Identifier, "id", "", "Custom client identifier") + flag.StringVar(&OutboundPort, "port", "30303", "listening port") + flag.BoolVar(&UseUPnP, "upnp", false, "enable UPnP support") + flag.IntVar(&MaxPeer, "maxpeer", 10, "maximum desired peers") + flag.IntVar(&RpcPort, "rpcport", 8080, "port to start json-rpc server on") + flag.BoolVar(&StartRpc, "rpc", false, "start rpc server") + flag.BoolVar(&NonInteractive, "y", false, "non-interactive mode (say yes to confirmations)") + flag.BoolVar(&UseSeed, "seed", true, "seed peers") + flag.BoolVar(&GenAddr, "genaddr", false, "create a new priv/pub key") + flag.BoolVar(&ExportKey, "export", false, "export private key") + flag.StringVar(&LogFile, "logfile", "", "log file (defaults to standard output)") + flag.StringVar(&ImportKey, "import", "", "imports the given private key (hex)") + flag.StringVar(&Datadir, "datadir", defaultDataDir(), "specifies the datadir to use") + flag.StringVar(&ConfigFile, "conf", defaultConfigFile, "config file") + flag.StringVar(&DebugFile, "debug", "", "debug file (no debugging if not set)") + flag.IntVar(&LogLevel, "loglevel", int(ethlog.InfoLevel), "loglevel: 0-4: silent,error,warn,info,debug)") + + flag.BoolVar(&StartMining, "mine", false, "start dagger mining") + flag.BoolVar(&StartJsConsole, "js", false, "launches javascript console") + + flag.Parse() + + InputFile = flag.Arg(0) +} |