X-Git-Url: http://git.ieval.ro/?p=gruntmaster-daemon.git;a=blobdiff_plain;f=lib%2FGruntmaster%2FDaemon%2FRunner%2FInteractive.pm;h=5a986754c8b6451471c91d0957f4bb1a6a787114;hp=115e7a198ac577b0d4cc555ca9fdfe3f1a8b8346;hb=c020b922b2b04878b04b8d7e84079087f1dc2abc;hpb=5f8de88806695f8907325fbbe8a689c4d8768f3d diff --git a/lib/Gruntmaster/Daemon/Runner/Interactive.pm b/lib/Gruntmaster/Daemon/Runner/Interactive.pm index 115e7a1..5a98675 100644 --- a/lib/Gruntmaster/Daemon/Runner/Interactive.pm +++ b/lib/Gruntmaster/Daemon/Runner/Interactive.pm @@ -23,8 +23,13 @@ sub run{ my $ret = fork // get_logger->logdie("Fork failed: $!"); if ($ret) { - $meta->{files}{prog}{run}->($meta->{files}{prog}{name}, fds => [qw/0 fifo1 1 >fifo2/], map {defined $meta->{$_} ? ($_ => $meta->{$_}) : () } qw/timeout mlimit/); - waitpid $ret, 0; + try { + $meta->{files}{prog}{run}->($meta->{files}{prog}{name}, fds => [qw/0 fifo1 1 >fifo2/], map {defined $meta->{$_} ? ($_ => $meta->{$_}) : () } qw/timeout mlimit/); + } catch { + die $_ + } finally { + waitpid $ret, 0; + }; die [WA, "Wrong Answer"] if $?; } else { try {