X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FPage%2FPb%2FEntry.pm;h=c9dfe206b3f8aacd080c6fc5a2817088e6dca562;hb=3da9c3c228106c819530a0b8e4c646981e6f71c9;hp=0f91c0128841386ebaed3e4a39a6afbdb9fc5a91;hpb=42546e6c1b709dc4c8d8e7048becc14278b6cdf0;p=plack-app-gruntmaster.git diff --git a/lib/Gruntmaster/Page/Pb/Entry.pm b/lib/Gruntmaster/Page/Pb/Entry.pm index 0f91c01..c9dfe20 100644 --- a/lib/Gruntmaster/Page/Pb/Entry.pm +++ b/lib/Gruntmaster/Page/Pb/Entry.pm @@ -11,21 +11,22 @@ 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/header footer/; +use Gruntmaster::Data qw/contest_start contest_end problem_name problem_statement/; use constant FORMATS => [qw/CPP/]; use constant TITLE => ''; my %templates = ( - en => <<'HTML', + en => <<'HTML', +

Submit solution

+ +
+
HTML ); @@ -40,18 +43,22 @@ $templates{$_} = header($_, TITLE) . $templates{$_} for keys %templates; $templates{$_} .= footer $_ for keys %templates; sub generate{ - my ($path, $lang) = @_; - $path = ($path =~ m,pb/(.*)/index,)[0]; - my $template = $templates{$_[1]}; - my $htc = HTML::Template::Compiled->new(scalarref => \$template); - flock my $metafh = IO::File->new("param(formats => FORMATS); - $htc->param(id => $path); - $htc->param(name => $meta->{name}); - $htc->param(statement => scalar slurp "pb/$path/statement.$lang"); - $htc->output + $_[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