[Zope-Checkins] CVS: StandaloneZODB/zdaemon - Daemon.py:1.8

Jeremy Hylton jeremy@zope.com
Wed, 8 May 2002 17:26:31 -0400


Update of /cvs-repository/StandaloneZODB/zdaemon
In directory cvs.zope.org:/tmp/cvs-serv20575

Modified Files:
	Daemon.py 
Log Message:
Move the detailed logging about an exited process to a helper
function.


=== StandaloneZODB/zdaemon/Daemon.py 1.7 => 1.8 ===
             return pid
 
+def log_pid(p, s):
+    if os.WIFEXITED(s):
+        es = os.WEXITSTATUS(s)
+        msg = "terminated normally, exit status: %s" % es
+    elif os.WIFSIGNALED(s):
+        signum = os.WTERMSIG(s)
+        signame = get_signal_name(signum)
+        msg = "terminated by signal %s(%s)" % (signame,
+                                              signum)
+        # We'd like to report whether a core file
+        # was produced, but there isn't a standard
+        # way to check.  It seems that some
+        # (many?) Unixes use bit 0x80 in the wait
+        # status, but how to tell?  A simple
+        # alternative is to assume that no core
+        # file was produced if the wait status is
+        # exactly equal to the signal.  Otherwise,
+        # there might be a core file and it's
+        # useful to print the wait status.
+        if signum != s:
+            msg += ", wait status: %s" % signum
+    else:
+        # XXX what should we do here?
+        signum = os.WSTOPSIG(s)
+        signame = get_signal_name(signum)
+        msg = "stopped by signal %s(%s)" % (signame,
+                                            signum)
+    pstamp('Aiieee! Process %s %s' % (p, msg),
+           zLOG.ERROR)
+    
 def run(argv, pidfile=''):
     if os.environ.has_key('ZDAEMON_MANAGED'):
         # We're the child at this point.
@@ -80,42 +110,15 @@
 
                 while 1: 
                     if not Heartbeat.BEAT_DELAY:
-                        p,s = os.waitpid(pid, 0)
+                        p, s = os.waitpid(pid, 0)
                     else:
-                        p,s = os.waitpid(pid, os.WNOHANG)
+                        p, s = os.waitpid(pid, os.WNOHANG)
                         if not p:
                             time.sleep(Heartbeat.BEAT_DELAY)
                             Heartbeat.heartbeat()
                             continue
                     if s:
-                        if os.WIFEXITED(s):
-                            es = os.WEXITSTATUS(s)
-                            msg = "terminated normally, exit status: %s" % es
-                        elif os.WIFSIGNALED(s):
-                            signum = os.WTERMSIG(s)
-                            signame = get_signal_name(signum)
-                            msg = "terminated by signal %s(%s)" % (signame,
-                                                                  signum)
-                            # We'd like to report whether a core file
-                            # was produced, but there isn't a standard
-                            # way to check.  It seems that some
-                            # (many?) Unixes use bit 0x80 in the wait
-                            # status, but how to tell?  A simple
-                            # alternative is to assume that no core
-                            # file was produced if the wait status is
-                            # exactly equal to the signal.  Otherwise,
-                            # there might be a core file and it's
-                            # useful to print the wait status.
-                            if signum != s:
-                                msg += ", wait status: %s" % signum
-                        else:
-                            # XXX what should we do here?
-                            signum = os.WSTOPSIG(s)
-                            signame = get_signal_name(signum)
-                            msg = "stopped by signal %s(%s)" % (signame,
-                                                                signum)
-                        pstamp('Aiieee! Process %s %s' % (p, msg),
-                               zLOG.ERROR)
+                        log_pid(p, s)
                     else:
                         pstamp(('The kid, %s, died on me.' % pid),
                                zLOG.WARNING)