# HG changeset patch # User Matt Johnston # Date 1341064846 -28800 # Node ID 16f96019a9e029234877486c57b4325a8317f6ab # Parent 41c3d817878db6c8553c43e4b4f3f326ea6c2195# Parent 55710361804b0b2ff7e9e736ef64183364041399 merge diff -r 55710361804b -r 16f96019a9e0 server/ts.py --- a/server/ts.py Fri Jun 29 22:46:59 2012 +0800 +++ b/server/ts.py Sat Jun 30 22:00:46 2012 +0800 @@ -25,6 +25,7 @@ import config from utils import monotonic_time, retry, readline, crc16 +import utils lightblue = None try: @@ -172,6 +173,9 @@ def main(): next_wake_time = 0 + if '--daemon' in sys.argv: + utils.cheap_daemon() + while True: sock = None try: diff -r 55710361804b -r 16f96019a9e0 server/utils.py --- a/server/utils.py Fri Jun 29 22:46:59 2012 +0800 +++ b/server/utils.py Sat Jun 30 22:00:46 2012 +0800 @@ -97,3 +97,31 @@ uc += 1 i += 1 return crc + +def cheap_daemon(): + print "Daemonising." + sys.stdout.flush() + sys.stderr.flush() + out = file('/dev/null', 'a+') + os.dup2(out.fileno(), sys.stdout.fileno()) + os.dup2(out.fileno(), sys.stderr.fileno()) + + try: + pid = os.fork() + if pid > 0: + sys.exit(0) + except OSError, e: + print>>sys.stderr, "Bad fork()" + sys.exit(1) + + os.setsid() + + try: + pid = os.fork() + if pid > 0: + sys.exit(0) + except OSError, e: + print>>sys.stderr, "Bad fork()" + sys.exit(1) + +