1995-10-13 23:34:21 -04:00
|
|
|
;;; Scsh routines for analysing exit codes returned by WAIT.
|
1999-08-06 09:28:52 -04:00
|
|
|
;;; Copyright (c) 1994 by Olin Shivers. See file COPYING.
|
1995-10-13 23:34:21 -04:00
|
|
|
;;;
|
|
|
|
;;; To port these to a new OS, consult /usr/include/sys/wait.h,
|
|
|
|
;;; and check the WIFEXITED, WEXITSTATUS, WIFSTOPPED, WSTOPSIG,
|
|
|
|
;;; WIFSIGNALED, and WTERMSIG macros for the magic fields they use.
|
|
|
|
;;; These definitions are for HPUX.
|
|
|
|
;;;
|
|
|
|
;;; I could have done a portable version by making C calls for this,
|
|
|
|
;;; but it's such overkill.
|
|
|
|
|
|
|
|
|
|
|
|
;;; If process terminated normally, return the exit code, otw #f.
|
|
|
|
|
|
|
|
(define (status:exit-val status)
|
|
|
|
(and (zero? (bitwise-and #xFF status))
|
|
|
|
(bitwise-and #xFF (arithmetic-shift status -8))))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
;;; If the process was suspended, return the suspending signal, otw #f.
|
|
|
|
|
|
|
|
(define (status:stop-sig status)
|
|
|
|
(and (= #x7F (bitwise-and status #xFF))
|
|
|
|
(bitwise-and #xFF (arithmetic-shift status -8))))
|
|
|
|
|
|
|
|
|
|
|
|
;;; If the process terminated abnormally,
|
|
|
|
;;; return the terminating signal, otw #f.
|
|
|
|
|
|
|
|
(define (status:term-sig status)
|
|
|
|
(let ((low-byte (bitwise-and status #xFF)))
|
|
|
|
(and (not (= low-byte 0)) ; Didn't exit.
|
|
|
|
(not (= low-byte #x7F)) ; Not suspended.
|
|
|
|
(bitwise-and status #x7F))))
|
|
|
|
|
|
|
|
|
|
|
|
;;; Flags.
|
|
|
|
(define wait/poll 1) ; Don't hang if nothing to wait for.
|
|
|
|
(define wait/stopped-children 2) ; Report on suspended subprocs, too.
|