]> iEval git - gruntmaster-page.git/blame - lib/Gruntmaster/Page/St.pm
Add missing </div> tag to pb_entry.en
[gruntmaster-page.git] / lib / Gruntmaster / Page / St.pm
CommitLineData
5bbf0128
MG
1package Gruntmaster::Page::St;
2
3use 5.014000;
4use strict;
5use warnings;
bb95f538
MG
6use Gruntmaster::Page::Base st => 'Standings';
7our @ISA = qw/Gruntmaster::Page::Base/;
5bbf0128
MG
8our $VERSION = '0.001';
9
d17951d1
MG
10use constant LEVEL_VALUES => {
11 beginner => 100,
12 easy => 250,
13 medium => 500,
14 hard => 1000,
15};
16
17sub calc_score{
ca3dffeb 18 my ($user, $problem, $date, $tries, $totaltime) = @_;
d17951d1
MG
19 my $mxscore = LEVEL_VALUES->{problem_level($problem)};
20 my $score = $mxscore;
21 my $timetaken = $date - get_open($problem, $user);
ca3dffeb
MG
22 $timetaken = 0 if $timetaken < 0;
23 $timetaken = 300 if $timetaken > $totaltime;
24 $score = ($totaltime - $timetaken) / $totaltime * $score;
d17951d1
MG
25 $score -= $tries / 10 * $mxscore;
26 $score = $mxscore * 3 / 10 if $score < $mxscore * 3 / 10;
27 int $score
28}
29
bb95f538 30sub _generate{
191f4979
MG
31 my ($self, $htc, $lang, $env, $ct) = @_;
32 debug $env => "language is '$lang' and contest is '$ct'";
a90230ea 33 my ($totaltime, $start);
5bbf0128 34
ca3dffeb 35 local $Gruntmaster::Data::contest;
7dc32473
MG
36 if ($ct) {
37 $start = contest_start ($ct);
38 $totaltime = contest_end ($ct) - $start;
39 $Gruntmaster::Data::contest = $ct;
ca3dffeb 40 }
cd9af27e 41
410a7b48
MG
42 my @problems = problems;
43 @problems = sort @problems;
d17951d1 44 my (%scores, %tries);
cd9af27e 45 for (1 .. jobcard) {
d17951d1
MG
46 if ($Gruntmaster::Data::contest) {
47 $tries{job_user()}{job_problem()}++;
a90230ea 48 $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;
cd9af27e 49 } else {
7dc32473
MG
50 if (job_result_text =~ m/^(\scores+)/) {
51 $scores{job_user()}{job_problem()} = $ct;
d17951d1
MG
52 } else {
53 $scores{job_user()}{job_problem()} = job_result() ? 0 : 100;
54 }
cd9af27e 55 }
5bbf0128 56 }
5bbf0128 57
cd9af27e
MG
58 my @st = sort { $b->{score} <=> $a->{score} } map {
59 my $user = $_;
60 +{
61 user => $user,
62 score => sum (values $scores{$user}),
63 scores => [map { $scores{$user}{$_} // '-'} @problems],
ca3dffeb 64 problems => $Gruntmaster::Data::contest,
cd9af27e
MG
65 }
66 } keys %scores;
746789c0 67 $htc->param(problems => [map { problem_name } @problems ]) if $Gruntmaster::Data::contest;
cd9af27e 68 $htc->param(st => \@st);
5bbf0128
MG
69}
70
711
This page took 0.040197 seconds and 4 git commands to generate.