AnyEvent-Process
view release on metacpan or search on metacpan
lib/AnyEvent/Process.pm view on Meta::CPAN
package AnyEvent::Process::Job;
use strict;
sub new {
my ($ref, $pid) = @_;
my $self = bless {pid => $pid, cbs => [], handles => [], timers => []}, $ref;
return $self;
}
sub kill {
my ($self, $signal) = @_;
return kill $signal, $self->{pid};
}
lib/AnyEvent/Process.pm view on Meta::CPAN
sub _add_cb {
my ($self, $cb) = @_;
push @{$self->{cbs}}, $cb;
}
sub _add_handle {
my ($self, $handle) = @_;
push @{$self->{handles}}, $handle;
}
sub _add_timer {
my ($self, $timer) = @_;
push @{$self->{timers}}, $timer;
}
sub _remove_cbs {
undef $_[0]->{cbs};
}
sub _remove_timers {
my $self = shift;
undef $_ foreach @{$self->{timers}};
undef $self->{timers};
}
sub close {
my $self = shift;
undef $_ foreach @{$self->{handles}};
undef $self->{handles};
}
package AnyEvent::Process;
use strict;
lib/AnyEvent/Process.pm view on Meta::CPAN
no strict 'refs';
my $method = $call->[0];
AE::log trace => "Calling handle method $method(" . join(', ', @{$call->[1]}) . ')';
$hdl->$method(@{$call->[1]});
}
$job->_add_handle($hdl);
}
# Create callbacks
my $completion_cb = sub {
$job->_remove_timers();
AE::log info => "Process $job->{pid} finished with code $_[1].";
$set_on_completion_args->($job, $_[1]);
};
$job->_add_cb(AE::child $pid, $callback_factory->($completion_cb));
$self->{job} = $job;
# Create watchdog and kill timers
my $on_kill = $proc_args{on_kill} // sub { $_[0]->kill(9) };
if (defined $proc_args{kill_interval}) {
my $kill_cb = sub {
$job->_remove_timers();
AE::log warn => "Process $job->{pid} is running too long, killing it.";
$on_kill->($job);
};
$job->_add_timer(AE::timer $proc_args{kill_interval}, 0, $kill_cb);
}
if (defined $proc_args{watchdog_interval} or defined $proc_args{on_watchdog}) {
unless (defined $proc_args{watchdog_interval} &&
defined $proc_args{on_watchdog}) {
croak "Both or none of watchdog_interval and on_watchdog must be defined";
}
my $watchdog_cb = sub {
AE::log info => "Executing watchdog for process $job->{pid}.";
unless ($proc_args{on_watchdog}->($job)) {
$job->_remove_timers();
AE::log warn => "Watchdog for process $job->{pid} failed, killing it.";
$on_kill->($job);
}
};
$job->_add_timer(AE::timer $proc_args{watchdog_interval}, $proc_args{watchdog_interval}, $watchdog_cb);
}
}
# We need this to allow AE collecting pending signals and prevent accumulation of zombies
$self->_yield;
return $job;
}
sub kill {
t/AnyEvent-Process-Decorator.t view on Meta::CPAN
is(<$my_err>, undef, 'Nothing else printed on STDERR');
undef $w_err;
}
$flop_err++;
};
$proc->run();
$cv->recv();
$cv = AE::cv;
my $w = AE::timer 2, 0, sub { $cv->send() };
$cv->recv();
( run in 1.243 second using v1.01-cache-2.11-cpan-49f99fa48dc )