summaryrefslogtreecommitdiffstats
path: root/stream.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2014-03-10 00:23:15 -0700
committerKaz Kylheku <kaz@kylheku.com>2014-03-10 00:23:15 -0700
commitfbb9921f8d29350fbc69e568f90cd66379502e9c (patch)
tree9794e7b902cb9c7be7f4d58a7a61e15d1f4362e5 /stream.c
parent110e155595d397e5328f6f7af33e430d1a361bbc (diff)
downloadtxr-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.c43
1 files changed, 22 insertions, 21 deletions
diff --git a/stream.c b/stream.c
index 912e6a80..7d073fc1 100644
--- a/stream.c
+++ b/stream.c
@@ -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;
}