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/cmd.go | |
parent | 456167aca0b795c625d6718ef8a06fe5fcb00c2e (diff) | |
download | dexon-1024766514eea7bb628ec6e5ed974e997b8faefc.tar dexon-1024766514eea7bb628ec6e5ed974e997b8faefc.tar.gz dexon-1024766514eea7bb628ec6e5ed974e997b8faefc.tar.bz2 dexon-1024766514eea7bb628ec6e5ed974e997b8faefc.tar.lz dexon-1024766514eea7bb628ec6e5ed974e997b8faefc.tar.xz dexon-1024766514eea7bb628ec6e5ed974e997b8faefc.tar.zst dexon-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/cmd.go')
-rw-r--r-- | ethereum/cmd.go | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/ethereum/cmd.go b/ethereum/cmd.go new file mode 100644 index 000000000..0e9c2be8c --- /dev/null +++ b/ethereum/cmd.go @@ -0,0 +1,33 @@ +package main + +import ( + "github.com/ethereum/eth-go" + "github.com/ethereum/go-ethereum/utils" + "os" + "io/ioutil" +) + +func InitJsConsole(ethereum *eth.Ethereum) { + repl := NewJSRepl(ethereum) + go repl.Start() + utils.RegisterInterrupt(func(os.Signal) { + repl.Stop() + ethereum.Stop() + }) +} + +func ExecJsFile (ethereum *eth.Ethereum, InputFile string) { + file, err := os.Open(InputFile) + if err != nil { + logger.Fatalln(err) + } + content, err := ioutil.ReadAll(file) + if err != nil { + logger.Fatalln(err) + } + re := NewJSRE(ethereum) + utils.RegisterInterrupt(func(os.Signal) { + re.Stop() + }) + re.Run(string(content)) +} |