diff options
author | Peter Stephenson <p.w.stephenson@ntlworld.com> | 2014-10-26 17:47:42 +0000 |
---|---|---|
committer | Peter Stephenson <p.w.stephenson@ntlworld.com> | 2014-10-26 17:47:42 +0000 |
commit | b4f7ccecd93ca9e64c3c3c774fdaefae83d7204a (patch) | |
tree | 492ba48008b5fa2c9370a7f4695540d6b8c7e89f /Doc/Zsh/builtins.yo | |
parent | e18b5bf0b2a1409ba5c88f8b61dbf65cdc235027 (diff) | |
download | zsh-b4f7ccecd93ca9e64c3c3c774fdaefae83d7204a.tar.gz zsh-b4f7ccecd93ca9e64c3c3c774fdaefae83d7204a.tar.xz zsh-b4f7ccecd93ca9e64c3c3c774fdaefae83d7204a.zip |
33531 with additions: retain status of exited background jobs.
Add linked list of unwaited-for background jobs. Truncate at value of _SC_CHILD_MAX discarding oldest. Remove old lastpid_status mechanism for latest exited process only. Slightly tighten safety of permanently allocated linked lists so that this doesn't compromise signal handling.
Diffstat (limited to 'Doc/Zsh/builtins.yo')
-rw-r--r-- | Doc/Zsh/builtins.yo | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/Doc/Zsh/builtins.yo b/Doc/Zsh/builtins.yo index 46f40cc3a..edc335e8b 100644 --- a/Doc/Zsh/builtins.yo +++ b/Doc/Zsh/builtins.yo @@ -2059,6 +2059,22 @@ then all currently active child processes are waited for. Each var(job) can be either a job specification or the process ID of a job in the job table. The exit status from this command is that of the job waited for. + +It is possible to wait for recent processes (specified by process ID, +not by job) that were running in the background even if the process has +exited. Typically the process ID will be recorded by capturing the +value of the variable tt($!) immediately after the process has been +started. There is a limit on the number of process IDs remembered by +the shell; this is given by the value of the system configuration +parameter tt(CHILD_MAX). When this limit is reached, older process IDs +are discarded, least recently started processes first. + +Note there is no protection against the process ID wrapping, i.e. if the +wait is not executed soon enough there is a chance the process waited +for is the wrong one. A conflict implies both process IDs have been +generated by the shell, as other processes are not recorded, and that +the user is potentially interested in both, so this problem is intrinsic +to process IDs. ) findex(whence) item(tt(whence) [ tt(-vcwfpams) ] var(name) ...)( |