diff options
-rw-r--r-- | pod/perlfunc.pod | 6 | ||||
-rw-r--r-- | pod/perlipc.pod | 11 |
2 files changed, 14 insertions, 3 deletions
diff --git a/pod/perlfunc.pod b/pod/perlfunc.pod index f47b6a5d86..f10927ed85 100644 --- a/pod/perlfunc.pod +++ b/pod/perlfunc.pod @@ -2378,7 +2378,7 @@ same as the number actually killed). kill 9, @goners; If SIGNAL is zero, no signal is sent to the process. This is a -useful way to check that the process is alive and hasn't changed +useful way to check that a child process is alive and hasn't changed its UID. See L<perlport> for notes on the portability of this construct. @@ -2386,7 +2386,9 @@ Unlike in the shell, if SIGNAL is negative, it kills process groups instead of processes. (On System V, a negative I<PROCESS> number will also kill process groups, but that's not portable.) That means you usually want to use positive not negative signals. You may also -use a signal name in quotes. See L<perlipc/"Signals"> for details. +use a signal name in quotes. + +See L<perlipc/"Signals"> for more details. =item last LABEL diff --git a/pod/perlipc.pod b/pod/perlipc.pod index 637030c726..8412bfd809 100644 --- a/pod/perlipc.pod +++ b/pod/perlipc.pod @@ -95,13 +95,22 @@ it doesn't kill itself): } Another interesting signal to send is signal number zero. This doesn't -actually affect another process, but instead checks whether it's alive +actually affect a child process, but instead checks whether it's alive or has changed its UID. unless (kill 0 => $kid_pid) { warn "something wicked happened to $kid_pid"; } +When directed at a process whose UID is not identical to that +of the sending process, signal number zero may fail because +you lack permission to send the signal, even though the process is alive. +You may be able to determine the cause of failure using C<$!>. + + unless (kill 0 => $pid or $! == $!{EPERM}) { + warn "$pid looks dead"; + } + You might also want to employ anonymous functions for simple signal handlers: |