2015-01-15 10:21:18 +01:00
|
|
|
#!/usr/bin/perl
|
|
|
|
|
|
|
|
use warnings;
|
|
|
|
use strict;
|
|
|
|
|
|
|
|
package _c_base;
|
|
|
|
use parent '_default';
|
|
|
|
|
|
|
|
sub postprocess {
|
|
|
|
my $self = shift;
|
|
|
|
|
|
|
|
# no errors compiling, but if output contains something, it must be diagnostic messages
|
|
|
|
if(length $self->{output}) {
|
|
|
|
$self->{output} =~ s/^\s+//;
|
|
|
|
$self->{output} =~ s/\s+$//;
|
|
|
|
$self->{output} = "[$self->{output}]\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
print "Executing gdb\n";
|
|
|
|
my $input_quoted = quotemeta $self->{input};
|
|
|
|
$input_quoted =~ s/\\"/"'\\"'"/g;
|
|
|
|
my ($retval, $result) = $self->execute(60, "bash -c \"date -s \@$self->{date}; ulimit -t 1; compiler_watchdog.pl $input_quoted > .output\"");
|
|
|
|
|
|
|
|
$result = "";
|
|
|
|
open(FILE, '.output');
|
|
|
|
while(<FILE>) {
|
|
|
|
$result .= $_;
|
|
|
|
last if length $result >= 1024 * 20;
|
|
|
|
}
|
|
|
|
close(FILE);
|
|
|
|
|
|
|
|
$result =~ s/\s+$//;
|
|
|
|
|
2015-01-17 02:30:09 +01:00
|
|
|
$self->{no_output} = 1 if not length $result;
|
|
|
|
|
2015-01-15 10:21:18 +01:00
|
|
|
$self->{output} .= $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
1;
|