Trace programs runned in Format.pm
[gruntmaster-daemon.git] / lib / Gruntmaster / Daemon / Format.pm
index c49ffc1ea1b1b7336efa8ad04b76691c40531def..5132fbd7387584d0f4ab8888a526e878c5f06ca3 100644 (file)
@@ -36,7 +36,9 @@ sub command_and_args{
 sub mkrun{
        my $format = shift;
        sub{
+               local *__ANON__ = 'mkrun_runner';
                my ($name, %args) = @_;
+               get_logger->trace("Running $name...");
                my $basename = fileparse $name, qr/\.[^.]*/;
                my $ret = fork // die 'Cannot fork';
                if ($ret) {
@@ -49,8 +51,8 @@ sub mkrun{
                        my $signame = sig_name $sig;
                        die [TLE, "Time Limit Exceeded"] if $tle;
                        die [OLE, 'Output Limit Exceeded'] if $sig && $signame eq 'XFSZ';
-                       die [DIED, "Crash (SIG$signame)"] if $sig;
-                       die [NZX, "Non-zero exit status: " . ($? >> 8)] if $?;
+                       die [DIED, "Crash (SIG$signame)"] if $sig && $signame != 'PIPE';
+                       die [NZX, "Non-zero exit status: " . ($? >> 8)] if $? >> 8;
                } else {
                        my @fds = exists $args{fds} ? @{$args{fds}} : ();
                        $^F = 50;
This page took 0.01004 seconds and 4 git commands to generate.