]> iEval git - plack-app-gruntmaster.git/commitdiff
Fix some small bugs
authorMarius Gavrilescu <marius@ieval.ro>
Tue, 14 Jan 2014 09:09:17 +0000 (11:09 +0200)
committerMarius Gavrilescu <marius@ieval.ro>
Tue, 14 Jan 2014 09:09:17 +0000 (11:09 +0200)
lib/Gruntmaster/Data.pm
lib/Gruntmaster/Page.pm
lib/Gruntmaster/Page/Log.pm
lib/Gruntmaster/Page/Pb.pm
lib/Gruntmaster/Page/Pb/Entry.pm

index f9162af3cfda71af69068f1cacbd69e8d727d129..544a6d060613d816a305c5e3ea6700a351523116 100644 (file)
@@ -16,8 +16,8 @@ sub dynsub{
 }
 
 BEGIN {
-       for my $cmd (qw/multi exec smembers get hget hset sadd incr hmset/) {
-               dynsub uc $cmd, sub { say $cmd;exit;$redis->$cmd(@_) };
+       for my $cmd (qw/multi exec smembers get hget hset sadd srem incr hmset hsetnx/) {
+               dynsub uc $cmd, sub { say "Arguments to \U$cmd: ", join ', ', @_; $redis->$cmd(@_) };
        }
 }
 
@@ -28,12 +28,16 @@ sub rexec                           ()              { EXEC }
 
 sub problems                   ()              { SMEMBERS cp . 'problem' }
 sub contests                   ()              { SMEMBERS cp . 'contest' }
-sub jobcard                    ()              { GET cp . 'job' }
+sub jobcard                            ()              { GET cp . 'job' }
 
-sub job_results                (_)     { decode_json HGET cp . "job.$_[0]", 'results' }
-sub set_job_results    ($+)    { HSET cp . "job.$_[0]", 'results', encode_json $_[1] }
-sub problem_meta               (_)     { decode_json HGET cp . "pb.$_[0]", 'meta' }
-sub set_problem_meta   ($+)    { HSET cp . "pb.$_[0]", 'meta', encode_json $_[1] }
+sub job_results                        (_)             { decode_json HGET cp . "job.$_[0]", 'results' }
+sub set_job_results            ($+)    { HSET cp . "job.$_[0]", 'results', encode_json $_[1] }
+sub job_inmeta                 (_)             { decode_json HGET cp . "job.$_[0]", 'inmeta' }
+sub set_job_inmeta             ($+)    { HSET cp . "job.$_[0]", 'inmeta', encode_json $_[1] }
+sub problem_meta               (_)             { decode_json HGET cp . "problem.$_[0]", 'meta' }
+sub set_problem_meta   ($+)    { HSET cp . "problem.$_[0]", 'meta', encode_json $_[1] }
+sub job_daemon                 (_)             { HGET cp . "job.$_[0]", 'daemon' }
+sub set_job_daemon             ($$)    { HSETNX cp . "job.$_[0]", 'daemon', $_[1] };
 
 sub defhash{
        my ($name, @keys) = @_;
@@ -47,6 +51,11 @@ sub defhash{
                SADD cp . $name, $key or return;
                HMSET cp . "$name.$key", %values;
        };
+       dynsub "remove_$name", sub (_) {
+               my $key = shift;
+               SREM cp . $name, $key;
+       };
+
        dynsub "push_$name", sub {
                my $nr = INCR cp . $name;
                HMSET cp . "$name.$nr", @_;
@@ -59,7 +68,7 @@ defhash job => qw/date file name private problem result result_text user/;
 
 our @EXPORT_OK = do {
        no strict 'refs';
-       grep { $_ =~ /^[a-z]/ and exists &$_ } keys %{__PACKAGE__ . '::'};
+       grep { $_ =~ /^[a-zA-Z]/ and exists &$_ } keys %{__PACKAGE__ . '::'};
 };
 
 1
index 6ca62ddd5ce18cef705e2173e3b93bbf35a2cb9d..5a6ed681eb835fcf214e7a70f322ad12ce22fc15 100644 (file)
@@ -41,7 +41,7 @@ sub declaregen{
        declaregen 'Log::Entry' => qr,^${contest}log/$component/index$,;
        declaregen Submit                       => qr,^${contest}submit$,;
        declaregen Pb                           => qr,^${contest}pb/index$,;
-       declaregen 'Pb::Entry'          => qr,^${contest}pb/$component/index$,;
+       declaregen 'Pb::Entry'          => qr,^${contest}pb/$component$,;
 }
 
 sub generate{
@@ -63,6 +63,7 @@ sub generate{
                        gzip \$page => "$path_noext.$lang.gz.$ext.new", Minimal => 1;
                        say $typemap "URI: $basename.$lang.gz.$ext\nContent-Language: $lang\nContent-Encoding: gzip\nContent-Type: " . CONTENT_TYPES->{$ext} . "\n";
                }
+               last
        }
 
        for my $lang (@{LANGUAGES()}) {
index a86b1532feef74dd1764a26ffc621948f8efd380..5a2b4c6a91d36cb13a846479f91f6baedb79ff05 100644 (file)
@@ -10,10 +10,14 @@ our $VERSION = '0.001';
 use constant TITLE => 'Job log';
 use constant PAGE_SIZE => 10;
 
+use constant FORMAT_EXTENSION => {
+  CPP => 'cpp',
+};
+
 use HTML::Template::Compiled;
 use POSIX qw/strftime/;
 use Gruntmaster::Page::Common qw/header footer/;
-use Gruntmaster::Data qw/job_date job_file job_name job_private job_problem job_result job_result_text job_user/;
+use Gruntmaster::Data qw/job_date job_file problem_name job_private job_problem job_result job_result_text job_user/;
 
 my %templates = (
        en => <<'HTML',
@@ -22,9 +26,9 @@ my %templates = (
 <tr><th>ID<th>Problem<th>Date<th>Size<th>User<th>Result
 <tbody>
 <tmpl_loop log><tr><td><a href="<tmpl_var id>"><tmpl_var id></a>
-<td><a href="/pb/<tmpl_var problem>"><tmpl_var name></a>
+<td><a href="../pb/<tmpl_var problem>"><tmpl_var name></a>
 <td><tmpl_var date>
-<td><tmpl_var size></a>
+<td><a href="src/<tmpl_var filename>"<tmpl_if private> data-private</tmpl_if>><tmpl_var size></a></a>
 <td><tmpl_var user><td class="r<tmpl_var result>"><tmpl_var result_text>
 </tmpl_loop>
 </table>
@@ -44,7 +48,7 @@ sub generate{
                id => $_,
                (job_private() ? (private => job_private) : ()),
                date => (job_date() ? strftime ('%c' => localtime job_date) : '?'),
-               name => job_name,
+               name => problem_name job_problem,
                problem => job_problem,
                result => job_result,
                result_text => job_result_text,
index 170f03f42d2b020235fe1924c62a2f6f0a9db3d0..5ada0e22b8a5ad07175140b570a299d33384cdb1 100644 (file)
@@ -21,27 +21,27 @@ my %templates = (
 <tmpl_if levels>
 <h2>Beginner</h2>
 <ul>
-<tmpl_loop beginner><li><a href="<tmpl_var id>"><tmpl_var name></a>
+<tmpl_loop beginner><li><a href="<tmpl_var id>.var"><tmpl_var name></a>
 </tmpl_loop></ul>
 
 <h2>Easy</h2>
 <ul>
-<tmpl_loop easy><li><a href="<tmpl_var id>"><tmpl_var name></a>
+<tmpl_loop easy><li><a href="<tmpl_var id>.var"><tmpl_var name></a>
 </tmpl_loop></ul>
 
 <h2>Medium</h2>
 <ul>
-<tmpl_loop medium><li><a href="<tmpl_var id>"><tmpl_var name></a>
+<tmpl_loop medium><li><a href="<tmpl_var id>.var"><tmpl_var name></a>
 </tmpl_loop></ul>
 
 <h2>Hard</h2>
 <ul>
-<tmpl_loop hard><li><a href="<tmpl_var id>"><tmpl_var name></a>
+<tmpl_loop hard><li><a href="<tmpl_var id>.var"><tmpl_var name></a>
 </tmpl_loop></ul>
 
 <tmpl_else>
 <ul>
-<tmpl_loop problems><li><a href="<tmpl_var id>"><tmpl_var name></a>
+<tmpl_loop problems><li><a href="<tmpl_var id>.var"><tmpl_var name></a>
 </tmpl_loop></ul>
 </tmpl_if>
 HTML
index ebcf56eca506752b8cee8631a0c615d9defdc196..c9dfe206b3f8aacd080c6fc5a2817088e6dca562 100644 (file)
@@ -43,7 +43,7 @@ $templates{$_}  = header($_, TITLE) . $templates{$_} for keys %templates;
 $templates{$_} .= footer $_ for keys %templates;
 
 sub generate{
-       $_[0] =~ m,(?:ct/([^/])+/)?log/(\w+)\.html$,;
+       $_[0] =~ m,(?:ct/([^/])+/)?pb/(\w+)\.html$,;
 
        my ($contest, $id) = ($1, $2);
        my $htc = HTML::Template::Compiled->new(scalarref => \$templates{$_[1]});
@@ -55,9 +55,9 @@ sub generate{
        }
        $htc->param(formats => FORMATS);
        $htc->param(id => $id);
-       local $Gruntmaster::Data::contest = ($_[0] =~ m,(?:ct/([^/])+/)?,)[0];
+       local $Gruntmaster::Data::contest = $contest if $contest;
        $htc->param(name => problem_name $id);
-       $htc->param(statement => problem_statement $id, $_[2]);
+       $htc->param(statement => problem_statement $id);
        $htc->output
 }
 
This page took 0.040049 seconds and 4 git commands to generate.