summaryrefslogtreecommitdiff
path: root/shell/ash.c
diff options
context:
space:
mode:
authorDenys Vlasenko2016-10-27 20:18:18 +0200
committerDenys Vlasenko2016-10-27 21:13:24 +0200
commit69188110146198c2c3fe7344c7d11dfac8891245 (patch)
tree326fcea82ac715d49d1b72d98a88888691ac00bf /shell/ash.c
parentb543bdadb3014661b6052c82b31e0012abc1e210 (diff)
downloadbusybox-69188110146198c2c3fe7344c7d11dfac8891245.zip
busybox-69188110146198c2c3fe7344c7d11dfac8891245.tar.gz
ash: open-code blocking_dowait_with_raise_on_sig()
There is in fact only one callsite. Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'shell/ash.c')
-rw-r--r--shell/ash.c25
1 files changed, 7 insertions, 18 deletions
diff --git a/shell/ash.c b/shell/ash.c
index 3a364dc..e21df32 100644
--- a/shell/ash.c
+++ b/shell/ash.c
@@ -4032,15 +4032,6 @@ dowait(int block, struct job *job)
return pid;
}
-static int
-blocking_dowait_with_raise_on_sig(void)
-{
- pid_t pid = dowait(DOWAIT_BLOCK, NULL);
- if (pid <= 0 && pending_sig)
- raise_exception(EXSIG);
- return pid;
-}
-
#if JOBS
static void
showjob(struct job *jp, int mode)
@@ -4229,19 +4220,14 @@ waitcmd(int argc UNUSED_PARAM, char **argv)
jp->waited = 1;
jp = jp->prev_job;
}
- blocking_dowait_with_raise_on_sig();
+ dowait(DOWAIT_BLOCK, NULL);
/* man bash:
* "When bash is waiting for an asynchronous command via
* the wait builtin, the reception of a signal for which a trap
* has been set will cause the wait builtin to return immediately
* with an exit status greater than 128, immediately after which
* the trap is executed."
- *
- * blocking_dowait_with_raise_on_sig raises signal handlers
- * if it gets no pid (pid < 0). However,
- * if child sends us a signal *and immediately exits*,
- * blocking_dowait_with_raise_on_sig gets pid > 0
- * and does not handle pending_sig. Check this case: */
+ */
if (pending_sig)
raise_exception(EXSIG);
}
@@ -4263,8 +4249,11 @@ waitcmd(int argc UNUSED_PARAM, char **argv)
job = getjob(*argv, 0);
}
/* loop until process terminated or stopped */
- while (job->state == JOBRUNNING)
- blocking_dowait_with_raise_on_sig();
+ while (job->state == JOBRUNNING) {
+ pid_t pid = dowait(DOWAIT_BLOCK, NULL);
+ if (pid <= 0 && pending_sig)
+ raise_exception(EXSIG);
+ }
job->waited = 1;
retval = getstatus(job);
repeat: ;