aboutsummaryrefslogtreecommitdiffstats
path: root/ethereal/main.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-07-01 19:45:39 +0800
committerobscuren <geffobscura@gmail.com>2014-07-01 19:45:39 +0800
commit253c23240b8cec56e2bb21072291e2f7ef1a49e9 (patch)
tree64503d09f1120ef2327a8184e46d5ee8bc7090bd /ethereal/main.go
parent0ce9003ba77c0552c9058caa55d2fea6711ac18c (diff)
parent098f7f23ce62d3f0c60d30d325576de93795cc4b (diff)
downloadgo-tangerine-253c23240b8cec56e2bb21072291e2f7ef1a49e9.tar.gz
go-tangerine-253c23240b8cec56e2bb21072291e2f7ef1a49e9.tar.zst
go-tangerine-253c23240b8cec56e2bb21072291e2f7ef1a49e9.zip
Merge branch 'feature/keys' of https://github.com/ethersphere/go-ethereum into ethersphere-feature/keys
Conflicts: .gitignore README.md
Diffstat (limited to 'ethereal/main.go')
-rw-r--r--ethereal/main.go66
1 files changed, 66 insertions, 0 deletions
diff --git a/ethereal/main.go b/ethereal/main.go
new file mode 100644
index 000000000..82427f088
--- /dev/null
+++ b/ethereal/main.go
@@ -0,0 +1,66 @@
+package main
+
+import (
+ "github.com/ethereum/eth-go/ethlog"
+ "github.com/ethereum/go-ethereum/ethereal/ui"
+ "github.com/ethereum/go-ethereum/utils"
+ "github.com/go-qml/qml"
+ "os"
+ "runtime"
+)
+
+func main() {
+ // Leave QT on top at ALL times. Qt Needs to be initialized from the main thread
+ qml.Init(nil)
+
+ runtime.GOMAXPROCS(runtime.NumCPU())
+
+ var interrupted = false
+ utils.RegisterInterrupt(func(os.Signal) {
+ interrupted = true
+ })
+
+ utils.HandleInterrupt()
+
+ // precedence: code-internal flag default < config file < environment variables < command line
+ Init() // parsing command line
+ utils.InitConfig(ConfigFile, Datadir, Identifier, "ETH")
+
+ utils.InitDataDir(Datadir)
+
+ utils.InitLogging(Datadir, LogFile, LogLevel, DebugFile)
+
+ db := utils.NewDatabase()
+
+ keyManager := utils.NewKeyManager(KeyStore, Datadir, db)
+
+ // create, import, export keys
+ utils.KeyTasks(keyManager, KeyRing, GenAddr, SecretFile, ExportDir, NonInteractive)
+
+ ethereum := utils.NewEthereum(db, keyManager, UseUPnP, OutboundPort, MaxPeer)
+
+ if ShowGenesis {
+ utils.ShowGenesis(ethereum)
+ }
+
+ if StartRpc {
+ utils.StartRpc(ethereum, RpcPort)
+ }
+
+ gui := ethui.New(ethereum, KeyRing, LogLevel)
+
+ utils.RegisterInterrupt(func(os.Signal) {
+ gui.Stop()
+ })
+ utils.StartEthereum(ethereum, UseSeed)
+ // gui blocks the main thread
+ gui.Start(AssetPath)
+ // we need to run the interrupt callbacks in case gui is closed
+ // this skips if we got here by actual interrupt stopping the GUI
+ if !interrupted {
+ utils.RunInterruptCallbacks(os.Interrupt)
+ }
+ // this blocks the thread
+ ethereum.WaitForShutdown()
+ ethlog.Flush()
+}