# we are the intermediate child
os._exit(0)
+ mypid = os.getpid()
+ if opts.pidfile is not None:
+ pfh = open(opts.pidfile, 'w')
+ print(mypid, file=pfh)
+ pfh.close()
+
logger = subprocess.Popen(['logger','-d',
'-t','hippotat(stderr)',
- '--id=%d' % os.getpid(),
+ '--id=%d' % mypid,
'-p',opts.syslogfacility + '.err'],
stdin=subprocess.PIPE,
stdout=subprocess.DEVNULL,
action='store_true', dest='daemon', default=False,
help='daemonize (and log to syslog)')
+optparser.add_option('--pidfile',
+ nargs=1, type='string',
+ action='store', dest='pidfile', default=None,
+ help='write pid to this file')
+
optparser.add_option('--syslog-facility',
nargs=1, type='string',action='store',
metavar='FACILITY', dest='syslogfacility',
def common_run():
log_debug(DBG.INIT, 'entering reactor')
if not _crashing: reactor.run()
- print('CRASHED (end)', file=sys.stderr)
+ print('ENDED', file=sys.stderr)