use 5.014000;
use strict;
use warnings;
-use parent qw/Exporter/;
-our @EXPORT_OK = qw/generate/;
+use Gruntmaster::Page::Base log_entry => 'Job <tmpl_var id>';
+our @ISA = qw/Gruntmaster::Page::Base/;
our $VERSION = '0.001';
-use HTML::Template::Compiled;
-use POSIX qw/strftime/;
-use Gruntmaster::Page::Common qw/cook_templates reload_templates/;
-use Gruntmaster::Data qw/job_results/;
-
-my %orig_templates = (
+use constant TEMPLATES => {
en => <<'HTML',
-<table border>
+Compiler output:
+<pre><tmpl_var errors></pre>
+
+Results:
+<table border class="table table-border table-striped">
<thead>
<tr><th>Test number<th>Result<th>Time
<tbody>
</tmpl_loop>
</table>
HTML
-);
-
-my %templates = cook_templates %orig_templates, log_entry => 'Job <tmpl_var id>';
+};
-sub generate{
- %templates = cook_templates %orig_templates, log_entry => 'Job <tmpl_var id>' if reload_templates;
- $_[0] =~ m,^(?:ct/([^/]+)/)?log/job/([^/]+)\.html$,;
- local $Gruntmaster::Data::contest = $1;
- my $id = $2;
+sub _generate{
+ my ($self, $htc, $lang, $env, $ct, $id) = @_;
+ debug $env => "language is '$lang', contest is '$ct' and id is '$id'";
+ local $Gruntmaster::Data::contest = $ct if $ct;
- my $htc = HTML::Template::Compiled->new(scalarref => \$templates{$_[1]});
+ my @tests = ();
- my @tests = map {
- $_->{time} = sprintf "%.4fs", $_->{time};
- $_
- } @{job_results $id};
+ eval {
+ @tests = map {
+ $_->{time} = sprintf "%.4fs", $_->{time};
+ $_
+ } @{job_results $id};
+ };
$htc->param(id => $id);
$htc->param(tests => \@tests);
- $htc->output
+ $htc->param(errors => job_errors $id)
}
1