use Gruntmaster::Daemon::Constants qw/ERR/;
use Gruntmaster::Daemon::Format qw/prepare_files stopvms/;
-use File::Basename qw/fileparse/;
use File::Temp qw/tempdir/;
use JSON qw/decode_json encode_json/;
use Sys::Hostname qw/hostname/;
use Try::Tiny;
use Log::Log4perl qw/get_logger/;
-use constant PAGE_SIZE => 10;
use constant FORMAT_EXTENSION => {
C => 'c',
CPP => 'cpp',
PASCAL => 'pas',
PERL => 'pl',
PYTHON => 'py',
+ SBCL => 'l',
};
##################################################
content => $job->source,
},
},
- map { $_ => $job->problem->get_column($_) } qw/generator runner judge testcnt timeout olimit/
+ map { $_ => $job->problem->get_column($_) } qw/generator runner judge precnt testcnt timeout olimit/
};
$meta->{tests} = decode_json $job->problem->tests if $meta->{runner} eq 'File';
+ delete $meta->{precnt} if $job->problem->is_in_archive;
+ $meta->{testcnt} = $meta->{precnt} if $meta->{precnt};
$meta->{files}{ver} = {
name => 'ver.' . FORMAT_EXTENSION->{$job->problem->verformat},
process $meta;
+ $meta->{result_text} .= ' (pretests)' if $meta->{precnt};
$job->update({
result => $meta->{result},
result_text => $meta->{result_text},
my $id = $job->id;
get_logger->debug("Taking job $id...");
my $daemon = hostname . ":$$";
- $job->update({daemon => $daemon});
- #if (set_job_daemon $job, hostname . ":$$") {
- if (1) {
+ $job->update({daemon => $daemon}, {where => {daemon => undef}})->discard_changes;
+ if ($job->daemon eq $daemon) {
get_logger->debug("Succesfully taken job $id");
process_job $job;
get_logger->debug("Job $id done");
} else {
- get_logger->debug("Job $id already taken");
+ get_logger->debug("Job $id already taken by " . $job->daemon);
}
}