X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FPage%2FPb%2FEntry.pm;h=dbfbe18ca42b86c6c2f0b7fd3a6b21de6518b503;hb=4aa8ba862bf3a79362df73c3d1e8707e8135af23;hp=6252b99877334bad5a3bffb7d218167d6c1f27ee;hpb=fe78f0c128c35e68e65850b02057997bad6717fe;p=plack-app-gruntmaster.git diff --git a/lib/Gruntmaster/Page/Pb/Entry.pm b/lib/Gruntmaster/Page/Pb/Entry.pm index 6252b99..dbfbe18 100644 --- a/lib/Gruntmaster/Page/Pb/Entry.pm +++ b/lib/Gruntmaster/Page/Pb/Entry.pm @@ -7,20 +7,15 @@ use parent qw/Exporter/; our @EXPORT_OK = qw/generate/; our $VERSION = '0.001'; -use Fcntl qw/:flock/; use HTML::Template::Compiled; -use IO::File; use POSIX qw/strftime/; -use YAML::Any qw/LoadFile/; -use File::Basename qw/fileparse/; -use File::Slurp qw/slurp/; -use Gruntmaster::Page qw/header footer/; +use Gruntmaster::Page::Common qw/cook_templates reload_templates/; +use Gruntmaster::Data qw/contest_start contest_end problem_name problem_statement/; use constant FORMATS => [qw/CPP/]; -use constant TITLE => ''; -my %templates = ( - en => <<'HTML', +my %orig_templates = ( + en => <<'HTML', @@ -35,35 +30,31 @@ my %templates = ( + HTML ); -$templates{$_} = header($_, TITLE) . $templates{$_} for keys %templates; -$templates{$_} .= footer $_ for keys %templates; +my %templates = cook_templates %orig_templates, pb_entry => ''; sub generate{ - my ($path, $lang) = @_; - my $contest; - $contest = $1 if $path =~ m,ct/([^/]*)/,; - my $id = ($path =~ m,pb/([^/]*)/index,)[0]; - $path =~ s,/index\.html$,,; - my $template = $templates{$_[1]}; - my $htc = HTML::Template::Compiled->new(scalarref => \$template); - flock my $metafh = IO::File->new("<$path/meta.yml"), LOCK_SH; - my $meta = LoadFile "$path/meta.yml"; - - $htc->param(cansubmit => 1); - if (defined $contest) { - my $meta = LoadFile "ct/$contest/meta.yml"; - $htc->param(cansubmit => time >= $meta->{start} && time <= $meta->{end}); - $htc->param(contest => $contest); - } - $htc->param(formats => FORMATS); - $htc->param(id => $id); - $htc->param(name => $meta->{name}); - $htc->param(statement => scalar slurp "$path/statement.$lang"); - $htc->output + %templates = cook_templates %orig_templates, pb_entry => '' if reload_templates; + $_[0] =~ 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(id => $id); + local $Gruntmaster::Data::contest = $contest if $contest; + $htc->param(name => problem_name $id); + $htc->param(statement => problem_statement $id); + $htc->output } 1