]> iEval git - gruntmaster-page.git/blobdiff - lib/Gruntmaster/Page/St.pm
Use Redis and reindent code
[gruntmaster-page.git] / lib / Gruntmaster / Page / St.pm
index f4d961e2dd12b7c586a1baf0a1a302669c77ef75..e5b418d26a7844767e06c053b8d5ac05175720dd 100644 (file)
@@ -9,16 +9,14 @@ our $VERSION = '0.001';
 
 use constant TITLE => 'Standings';
 
-use Fcntl qw/:flock/;
 use HTML::Template::Compiled;
-use IO::File;
 use List::Util qw/sum/;
 use POSIX qw/strftime/;
-use YAML::Any qw/LoadFile/;
 use Gruntmaster::Page::Common qw/header footer/;
+use Gruntmaster::Data qw/problems jobcard job_result_text job_result job_problem job_user/;
 
 my %templates = (
-  en => <<'HTML',
+       en => <<'HTML',
 <table border>
 <thead>
 <tr><th>Username<tmpl_loop problems><th><tmpl_var _></tmpl_loop><th>Total
@@ -35,35 +33,30 @@ $templates{$_}  = header($_, TITLE) . $templates{$_} for keys %templates;
 $templates{$_} .= footer $_ for keys %templates;
 
 sub generate{
-  my ($path, $lang) = @_;
-  $path =~ s,/st\.html$,,;
-  my $template = $templates{$lang};
-  my $htc = HTML::Template::Compiled->new(scalarref => \$template);
-  IO::File->new(">$path/meta.yml")->close unless -f "$path/meta.yml";
-  flock my $metafh = IO::File->new("<$path/meta.yml"), LOCK_SH;
-  my $meta = LoadFile "$path/meta.yml";
-  my @problems = sort grep { /^\w+$/ } map { s,.*/,,r } <$path/../pb/*>;
-  my %scores;
-  for (1 .. $meta->{last}) {
-       my $meta = LoadFile "$path/$_/meta.yml";
-       if ($meta->{result_text} =~ m/^(\d+)/) {
-         $scores{$meta->{user}}{$meta->{problem}} = $1;
-       } else {
-         $scores{$meta->{user}}{$meta->{problem}} = $meta->{result} ? 0 : 100;
+       local $Gruntmaster::Data::contest = ($_[0] =~ m,^ct/([^/]+)/,)[0];
+       my $htc = HTML::Template::Compiled->new(scalarref => \$templates{$_[1]});
+
+       my @problems = sort problems;
+       my %scores;
+       for (1 .. jobcard) {
+               if (job_result_text =~ m/^(\d+)/) {
+                       $scores{job_user()}{job_problem()} = $1;
+               } else {
+                       $scores{job_user()}{job_problem()} = job_result() ? 0 : 100;
+               }
        }
-  }
 
-  my @st = sort { $b->{score} <=> $a->{score} } map {
-       my $user = $_;
-       +{
-         user => $user,
-         score => sum (values $scores{$user}),
-         scores => [map { $scores{$user}{$_} // '-'} @problems],
-       }
-  } keys %scores;
-  $htc->param(problems => \@problems);
-  $htc->param(st => \@st);
-  $htc->output
+       my @st = sort { $b->{score} <=> $a->{score} } map {
+               my $user = $_;
+               +{
+                       user => $user,
+                       score => sum (values $scores{$user}),
+                       scores => [map { $scores{$user}{$_} // '-'} @problems],
+               }
+       } keys %scores;
+       $htc->param(problems => \@problems);
+       $htc->param(st => \@st);
+       $htc->output
 }
 
 1
This page took 0.024408 seconds and 4 git commands to generate.