move start_daemon code to main script
authorThomasV <thomasv@gitorious>
Tue, 11 Mar 2014 07:33:58 +0000 (08:33 +0100)
committerThomasV <thomasv@gitorious>
Tue, 11 Mar 2014 07:33:58 +0000 (08:33 +0100)
electrum
lib/__init__.py
lib/daemon.py

index f3b05f5..90de2ea 100755 (executable)
--- a/electrum
+++ b/electrum
@@ -108,33 +108,49 @@ def print_help_cb(self, opt, value, parser):
 
 
 def run_command(cmd, password=None, args=[]):
-    import xmlrpclib, socket
-    cmd_runner = Commands(wallet, network)
-    func = getattr(cmd_runner, cmd.name)
-    cmd_runner.password = password
-
+    import socket
     if cmd.requires_network and not options.offline:
-
+        daemon_started = False
         while True:
             try:
-                cmd_runner.network = NetworkProxy(config)
-                cmd_runner.network.start()
+                network = NetworkProxy(config)
                 break
             except socket.error:
-                if cmd.name != 'daemon':
-                    print "Starting daemon [%s]"%config.get('server')
-                    start_daemon(config)
+                if cmd != 'daemon':
+                    if not daemon_started:
+                        print "Starting daemon [%s]"%config.get('server')
+                        daemon_started = True
+                        pid = os.fork()
+                        if (pid == 0): # The first child.
+                            os.chdir("/")
+                            os.setsid()
+                            os.umask(0)
+                            pid2 = os.fork()
+                            if (pid2 == 0):  # Second child
+                                server = NetworkServer(config)
+                                try:
+                                    server.main_loop()
+                                except KeyboardInterrupt:
+                                    print "Ctrl C - Stopping server"
+                                sys.exit(1)
+                            sys.exit(0)
+                    else:
+                        time.sleep(0.1)
                 else:
                     print "Daemon not running"
                     sys.exit(1)
 
+        network = network
+        network.start()
         if wallet:
-            wallet.start_threads(cmd_runner.network)
+            wallet.start_threads(network)
             wallet.update()
     else:
-        cmd_runner.network = None
-
+        network = None
 
+    cmd_runner = Commands(wallet, network)
+    func = getattr(cmd_runner, cmd.name)
+    cmd_runner.password = password
     try:
         result = func(*args[1:])
     except Exception:
index d01b645..e85805a 100644 (file)
@@ -14,4 +14,4 @@ from plugins import BasePlugin
 from mnemonic import mn_encode as mnemonic_encode
 from mnemonic import mn_decode as mnemonic_decode
 from commands import Commands, known_commands
-from daemon import start_daemon, NetworkProxy
+from daemon import NetworkProxy, NetworkServer
index 7eb0881..8489dab 100644 (file)
@@ -295,28 +295,6 @@ class NetworkServer:
 
 
 
-def start_daemon(config):
-    pid = os.fork()
-    if (pid == 0): # The first child.
-        os.chdir("/")
-        os.setsid()
-        os.umask(0)
-        pid2 = os.fork()
-        if (pid2 == 0):  # Second child
-            server = NetworkServer(config)
-            try:
-                server.main_loop()
-            except KeyboardInterrupt:
-                print "Ctrl C - Stopping server"
-            sys.exit(1)
-
-        sys.exit(0)
-
-    # should use a signal
-    time.sleep(2)
-
-
-
 if __name__ == '__main__':
     import simple_config
     config = simple_config.SimpleConfig({'verbose':True, 'server':'ecdsa.net:50002:s'})