X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FPage%2FSt.pm;h=316a92b46f5c1f5ea555e0fbf43cf64fdf0b7c3c;hb=8f22df6957b4f6feac7c6bf27d1ffe22cb89ee6a;hp=5803183be0fc49994a93bc641f969582e6d02e65;hpb=191f4979def520b8be01554eb954c80ee42df38b;p=plack-app-gruntmaster.git
diff --git a/lib/Gruntmaster/Page/St.pm b/lib/Gruntmaster/Page/St.pm
index 5803183..316a92b 100644
--- a/lib/Gruntmaster/Page/St.pm
+++ b/lib/Gruntmaster/Page/St.pm
@@ -7,27 +7,10 @@ use Gruntmaster::Page::Base st => 'Standings';
our @ISA = qw/Gruntmaster::Page::Base/;
our $VERSION = '0.001';
-use constant TEMPLATES => {
- en => <<'HTML',
-
-
-UsernameTotal
-Username | Score
-
-
- |
-
-
-
-
- | | | | | |
---|
-HTML
-};
-
use constant LEVEL_VALUES => {
beginner => 100,
easy => 250,
- medium => 500,
+ medium => 600,
hard => 1000,
};
@@ -63,8 +46,8 @@ sub _generate{
if ($Gruntmaster::Data::contest) {
$tries{job_user()}{job_problem()}++;
$scores{job_user()}{job_problem()} = job_result() ? 0 : calc_score (job_user(), job_problem(), job_date(), $tries{job_user()}{job_problem()}, $totaltime) if job_date() > $start;
- } else {
- if (job_result_text =~ m/^(\scores+)/) {
+ } elsif (defined job_user && defined job_problem && defined job_result) {
+ if (defined job_result_text && job_result_text =~ m/^(\scores+)/) {
$scores{job_user()}{job_problem()} = $ct;
} else {
$scores{job_user()}{job_problem()} = job_result() ? 0 : 100;
@@ -72,7 +55,7 @@ sub _generate{
}
}
- my @st = sort { $b->{score} <=> $a->{score} } map {
+ my @st = sort { $b->{score} <=> $a->{score} or $a->{user} cmp $b->{user}} map {
my $user = $_;
+{
user => $user,
@@ -81,6 +64,9 @@ sub _generate{
problems => $Gruntmaster::Data::contest,
}
} keys %scores;
+
+ $st[0]->{rank} = 1;
+ $st[$_]->{rank} = $st[$_ - 1]->{rank} + ($st[$_]->{score} < $st[$_ - 1]->{score}) for 1 .. $#st;
$htc->param(problems => [map { problem_name } @problems ]) if $Gruntmaster::Data::contest;
$htc->param(st => \@st);
}