Developer(s) | AT&T Bell Laboratories |
---|---|
Initial release | November 1973; 51 years ago (1973-11) |
Operating system | Unix and Unix-like |
Type | Command |
In Unix shells, wait
is a command which pauses until execution of a background process has ended.
Usage
wait
where n is the pid or job ID of a currently executing background process (job). If n is not given, the command waits until all jobs known to the invoking shell have terminated.
wait normally returns the exit status of the last job which terminated. It may also return 127 in the event that n specifies a non-existent job or zero if there were no jobs to wait for.
Because wait
needs to be aware of the job table of the current shell execution environment, it is usually implemented as a shell builtin.
Example
This command can be useful where part of a script can execute in parallel to implement a barrier where an upcoming section depends on the successful completion of the preceding sections.
The following example will fetch the src/ directory from a machine named iona using rsync and simultaneously update the libraries on which this program depends, before building the combination.
#!/usr/bin/env bash # Parallel update script which makes use of the wait command # Update local copy rsync iona:src/ . & # Upgrade required libraries, or exit indicating failure if make failed for some reason make -C lib || exit 1 # Wait for rsync to terminate (may have already happened) and finish the job wait make
Wait for specified job control id number:
$ ls -R / > /dev/null 2>&1 & # start any long running background process 1986 $ wait %2 # waits for background job number 2 to terminate, then returns
See also
External links
Unix command-line interface programs and shell builtins | |
---|---|
File system | |
Processes | |
User environment | |
Text processing | |
Shell builtins | |
Searching | |
Documentation | |
Software development | |
Miscellaneous | |
|