X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FPage%2FPb%2FEntry.pm;h=dbf66b47457f419d8dbc4403468f2f00650cabad;hb=c2a23f84f4699ce135f517450a0bc153410ca223;hp=c9dfe206b3f8aacd080c6fc5a2817088e6dca562;hpb=3da9c3c228106c819530a0b8e4c646981e6f71c9;p=plack-app-gruntmaster.git diff --git a/lib/Gruntmaster/Page/Pb/Entry.pm b/lib/Gruntmaster/Page/Pb/Entry.pm index c9dfe20..dbf66b4 100644 --- a/lib/Gruntmaster/Page/Pb/Entry.pm +++ b/lib/Gruntmaster/Page/Pb/Entry.pm @@ -3,24 +3,13 @@ package Gruntmaster::Page::Pb::Entry; use 5.014000; use strict; use warnings; -use parent qw/Exporter/; -our @EXPORT_OK = qw/generate/; +use Gruntmaster::Page::Base pb_entry => ''; +our @ISA = qw/Gruntmaster::Page::Base/; our $VERSION = '0.001'; -use Fcntl qw/:flock/; -use HTML::Template::Compiled; -use IO::File; -use POSIX qw/strftime/; -use File::Basename qw/fileparse/; -use Gruntmaster::Page::Common qw/header footer/; -use Gruntmaster::Data qw/contest_start contest_end problem_name problem_statement/; - -use constant FORMATS => [qw/CPP/]; -use constant TITLE => ''; - -my %templates = ( +use constant TEMPLATES => { en => <<'HTML', - +

Submit solution

@@ -37,28 +26,25 @@ my %templates = (
HTML -); +}; -$templates{$_} = header($_, TITLE) . $templates{$_} for keys %templates; -$templates{$_} .= footer $_ for keys %templates; +sub _generate{ + my ($self, $htc, $path, $lang) = @_; -sub generate{ - $_[0] =~ m,(?:ct/([^/])+/)?pb/(\w+)\.html$,; + $path =~ m,(?:ct/([^/])+/)?pb/(\w+)\.html$,; my ($contest, $id) = ($1, $2); - my $htc = HTML::Template::Compiled->new(scalarref => \$templates{$_[1]}); $htc->param(cansubmit => 1); if (defined $contest) { $htc->param(cansubmit => time >= contest_start $contest && time <= contest_end $contest); $htc->param(contest => $contest); } - $htc->param(formats => FORMATS); + $htc->param(formats => Gruntmaster::Page::Submit::FORMATS); $htc->param(id => $id); local $Gruntmaster::Data::contest = $contest if $contest; $htc->param(name => problem_name $id); $htc->param(statement => problem_statement $id); - $htc->output } 1