NAME
Reflex::PID - Observe the exit of a subprocess by its SIGCHLD signal.
VERSION
version 0.050
SYNOPSIS
# Not a complete program. Please see the source for # Reflex::POE::Wheel::Run for one example.
use Reflex::PID;
has sigchild_watcher => (
isa => 'Reflex::PID|Undef',
is => 'rw',
traits => ['Reflex::Trait::Observed'],
role => 'sigchld',
);
sub some_method {
my $self = shift;
my $pid = fork();
die $! unless defined $pid;
exec("some-program.pl") unless $pid;
# Parent here.
$self->sigchild_watcher(
Reflex::PID->new(pid => $pid)
);
}
sub on_sigchld_signal {
# Handle the event.
}
DESCRIPTION
Reflex::PID waits for a particular child process to exit. It emits a "signal" event with information about the child process when it has detected the child has exited.
Since Reflex::PID waits for a particular process ID, it's pretty much useless afterwards. Consider pairing it with Reflex::Collection if you have to maintain several transient processes.
Reflex::PID extends Reflex::Signal to handle a particular kind of signal---SIGCHLD.
TODO - However, first we need to make Reflex::PID objects stop themselves and emit "stopped" events when they're done. Otherwise Reflex::Collection won't know when to destroy them.
Public Events
signal
Reflex::PID's "signal" event includes two named parameters. "pid" contains the process ID that exited. "exit" contains the process' exit value---a copy of $?
at the time the process exited. Please see "$?" in perlvar for more information about that special Perl variable.
SEE ALSO
Reflex Reflex::Signal Reflex::POE::Wheel::Run
"ACKNOWLEDGEMENTS" in Reflex "ASSISTANCE" in Reflex "AUTHORS" in Reflex "BUGS" in Reflex "BUGS" in Reflex "CONTRIBUTORS" in Reflex "COPYRIGHT" in Reflex "LICENSE" in Reflex "TODO" in Reflex