diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2014-03-10 00:23:15 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2014-03-10 00:23:15 -0700 |
commit | fbb9921f8d29350fbc69e568f90cd66379502e9c (patch) | |
tree | 9794e7b902cb9c7be7f4d58a7a61e15d1f4362e5 /stream.c | |
parent | 110e155595d397e5328f6f7af33e430d1a361bbc (diff) | |
download | txr-fbb9921f8d29350fbc69e568f90cd66379502e9c.tar.gz txr-fbb9921f8d29350fbc69e568f90cd66379502e9c.tar.bz2 txr-fbb9921f8d29350fbc69e568f90cd66379502e9c.zip |
* stream.c (pipe_close): Restructured the function a bit.
Do not throw exceptions for normal process terminations, only for
abnormal ones (terminated by a signal). Return the termination
status instead of just t.
* txr.1: Fixed the neglected documentation of the optional boolean
argument of close-stream. Described the behaviors with regard
to pipes in more detail.
Diffstat (limited to 'stream.c')
-rw-r--r-- | stream.c | 43 |
1 files changed, 22 insertions, 21 deletions
@@ -654,36 +654,37 @@ static val pipe_close(val stream, val throw_on_error) #endif h->f = 0; - if (status != 0 && throw_on_error) { - if (status < 0) { + if (status < 0) { + if (throw_on_error) uw_throwf(process_error_s, lit("unable to obtain status of command ~a: ~a/~s"), stream, num(errno), string_utf8(strerror(errno)), nao); + } else { #ifdef HAVE_SYS_WAIT + if (throw_on_error) { + if (WIFSIGNALED(status)) { + int termsig = WTERMSIG(status); + uw_throwf(process_error_s, lit("pipe ~a terminated by signal ~a"), + stream, num(termsig), nao); #ifndef WIFCONTINUED #define WIFCONTINUED(X) 0 #endif - } else if (WIFEXITED(status)) { + } else if (WIFSTOPPED(status) || WIFCONTINUED(status)) { + uw_throwf(process_error_s, + lit("processes of closed pipe ~a still running"), + stream, nao); + } + } + if (WIFEXITED(status)) { int exitstatus = WEXITSTATUS(status); - uw_throwf(process_error_s, lit("pipe ~a terminated with status ~a"), - stream, num(exitstatus), nao); - } else if (WIFSIGNALED(status)) { - int termsig = WTERMSIG(status); - uw_throwf(process_error_s, lit("pipe ~a terminated by signal ~a"), - stream, num(termsig), nao); - - } else if (WIFSTOPPED(status) || WIFCONTINUED(status)) { - uw_throwf(process_error_s, - lit("processes of closed pipe ~a still running"), - stream, nao); - } else { - uw_throwf(file_error_s, lit("strange status in when closing pipe ~a"), - stream, nao); -#endif + return num(exitstatus); } - } - - return status == 0 ? t : nil; +#else + if (status != 0 && throw_on_error) + uw_throwf(process_error_s, lit("closing pipe ~a failed"), stream, nao); +#endif + return status == 0 ? zero : nil; + } } return nil; } |