aboutsummaryrefslogtreecommitdiffstats
path: root/cmd/mist/main.go
diff options
context:
space:
mode:
Diffstat (limited to 'cmd/mist/main.go')
-rw-r--r--cmd/mist/main.go95
1 files changed, 95 insertions, 0 deletions
diff --git a/cmd/mist/main.go b/cmd/mist/main.go
new file mode 100644
index 000000000..c6cca9de5
--- /dev/null
+++ b/cmd/mist/main.go
@@ -0,0 +1,95 @@
+package main
+
+import (
+ "os"
+ "runtime"
+
+ "github.com/ethereum/go-ethereum"
+ "github.com/ethereum/go-ethereum/ethlog"
+ "github.com/ethereum/go-ethereum/utils"
+ "gopkg.in/qml.v1"
+)
+
+const (
+ ClientIdentifier = "Mist"
+ Version = "0.7.1"
+)
+
+var ethereum *eth.Ethereum
+
+func run() error {
+ // precedence: code-internal flag default < config file < environment variables < command line
+ Init() // parsing command line
+
+ config := utils.InitConfig(VmType, ConfigFile, Datadir, "ETH")
+
+ utils.InitDataDir(Datadir)
+
+ stdLog := utils.InitLogging(Datadir, LogFile, LogLevel, DebugFile)
+
+ db := utils.NewDatabase()
+ err := utils.DBSanityCheck(db)
+ if err != nil {
+ ErrorWindow(err)
+
+ os.Exit(1)
+ }
+
+ keyManager := utils.NewKeyManager(KeyStore, Datadir, db)
+
+ // create, import, export keys
+ utils.KeyTasks(keyManager, KeyRing, GenAddr, SecretFile, ExportDir, NonInteractive)
+
+ clientIdentity := utils.NewClientIdentity(ClientIdentifier, Version, Identifier)
+
+ ethereum = utils.NewEthereum(db, clientIdentity, keyManager, UseUPnP, OutboundPort, MaxPeer)
+
+ if ShowGenesis {
+ utils.ShowGenesis(ethereum)
+ }
+
+ if StartRpc {
+ utils.StartRpc(ethereum, RpcPort)
+ }
+
+ gui := NewWindow(ethereum, config, clientIdentity, KeyRing, LogLevel)
+ gui.stdLog = stdLog
+
+ utils.RegisterInterrupt(func(os.Signal) {
+ gui.Stop()
+ })
+ utils.StartEthereum(ethereum, UseSeed)
+ // gui blocks the main thread
+ gui.Start(AssetPath)
+
+ return nil
+}
+
+func main() {
+ runtime.GOMAXPROCS(runtime.NumCPU())
+
+ // This is a bit of a cheat, but ey!
+ os.Setenv("QTWEBKIT_INSPECTOR_SERVER", "127.0.0.1:99999")
+
+ qml.Run(run)
+
+ var interrupted = false
+ utils.RegisterInterrupt(func(os.Signal) {
+ interrupted = true
+ })
+
+ utils.HandleInterrupt()
+
+ if StartWebSockets {
+ utils.StartWebSockets(ethereum)
+ }
+
+ // 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()
+}