]> iEval git - gruntmaster-daemon.git/blame_incremental - lib/Gruntmaster/Daemon/Runner/Interactive.pm
Add javascript
[gruntmaster-daemon.git] / lib / Gruntmaster / Daemon / Runner / Interactive.pm
... / ...
CommitLineData
1package Gruntmaster::Daemon::Runner::Interactive;
2
3use 5.014000;
4use strict;
5use warnings;
6
7use File::Slurp qw/slurp/;
8use Gruntmaster::Daemon::Constants qw/WA/;
9use Log::Log4perl qw/get_logger/;
10use POSIX qw/mkfifo/;
11use Try::Tiny;
12
13our $VERSION = '5999.000_005';
14
15##################################################
16
17sub run{
18 my ($test, $meta) = @_;
19 get_logger->trace("Running on test $test...");
20
21 mkfifo 'fifo1', 0600 or die "$!\n" unless -e 'fifo1';
22 mkfifo 'fifo2', 0600 or die "$!\n" unless -e 'fifo2';
23
24 my @fds = $ENV{GRUNTMASTER_VM} ? qw,0 /dev/ttyS1 1 >/dev/ttyS1, : qw/0 fifo1 1 >fifo2/;
25 $meta->{files}{prog}{run}->($meta->{files}{prog}{name}, nonblocking => 1, fds => \@fds, map { $_ => $meta->{$_} } qw/timeout mlimit/);
26
27 my $fail;
28 @fds = $ENV{GRUNTMASTER_VM} ? qw,1 >/dev/ttyS1 0 /dev/ttyS1, : qw/1 >fifo1 0 fifo2/;
29 try {
30 $meta->{files}{ver}{run}->($meta->{files}{ver}{name}, fds => [@fds, qw,3 input 4 >result,], args => [$test], map { $_ => $meta->{$_} } qw/timeout mlimit/);
31 } catch {
32 $fail = [WA, 'Wrong Answer'];
33 };
34
35 try {
36 Gruntmaster::Daemon::Format::execlist_finish(prog => !$fail);
37 } catch {
38 $fail = $_;
39 };
40
41 unlink 'fifo1';
42 unlink 'fifo2';
43
44 die $fail if $fail; ## no critic (RequireCarping)
45 scalar slurp 'result' or 'Ok'
46}
47
481;
49__END__
50
51=encoding utf-8
52
53=head1 NAME
54
55Gruntmaster::Daemon::Runner::Interactive - Make an interactive verifier talk to the program
56
57=head1 SYNOPSIS
58
59 use Gruntmaster::Daemon::Runner::Interactive;
60 Gruntmaster::Daemon::Runner::Interactive::run(5, $meta);
61
62=head1 DESCRIPTION
63
64B<WARNING: This runner is experimental!>
65
66Gruntmaster::Daemon::Runner::Interactive is a runner which runs the program and an interactive verifier in parallel, connecting each program's STDIN to the other's STDOUT. The verifier, C<< $meta->{files}{ver} >>, should return nonzero if the program gives an incorrect answer, or print the test score to fd 4 then return 0 if the answer is correct.
67
68=head1 AUTHOR
69
70Marius Gavrilescu E<lt>marius@ieval.roE<gt>
71
72=head1 COPYRIGHT AND LICENSE
73
74Copyright (C) 2014 by Marius Gavrilescu
75
76This library is free software: you can redistribute it and/or modify
77it under the terms of the GNU Affero General Public License as published by
78the Free Software Foundation, either version 3 of the License, or
79(at your option) any later version.
80
81
82=cut
This page took 0.025223 seconds and 4 git commands to generate.