X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FPage%2FLog.pm;h=14d9c62d6d1f1e548e349ae0bcba7e19388829a7;hb=c2a23f84f4699ce135f517450a0bc153410ca223;hp=fce36cbe8fe1a4f5d91b3082c528a9cb18060bcb;hpb=bb95f538bf263c0294d87cfb90d58c66117b9aab;p=plack-app-gruntmaster.git diff --git a/lib/Gruntmaster/Page/Log.pm b/lib/Gruntmaster/Page/Log.pm index fce36cb..14d9c62 100644 --- a/lib/Gruntmaster/Page/Log.pm +++ b/lib/Gruntmaster/Page/Log.pm @@ -10,7 +10,14 @@ our $VERSION = '0.001'; use constant PAGE_SIZE => 10; use constant FORMAT_EXTENSION => { - CPP => 'cpp', + C => 'c', + CPP => 'cpp', + MONO => 'cs', + JAVA => 'java', + PASCAL => 'pas', + PERL => 'pl', + PYTHON => 'py', + RUBY => 'rb', }; use constant TEMPLATES => { @@ -33,8 +40,8 @@ sub _generate{ my ($self, $htc, $path, $lang) = @_; $path =~ m,^(?:ct/([^/]+)/)?log/(\w+)\.html$,; - local $Gruntmaster::Data::contest = $1; - my $pages = jobcard / PAGE_SIZE; + local $Gruntmaster::Data::contest = $1 if $1; + my $pages = POSIX::ceil (jobcard / PAGE_SIZE); my $page = $2 eq 'index' ? $pages : $2; my @log = sort { $b->{id} <=> $a->{id} } map +{ @@ -47,7 +54,7 @@ sub _generate{ result => job_result, result_text => job_result_text, size => sprintf ("%.2f KiB", job_filesize() / 1024), - user => job_user}, ($page - 1) * PAGE_SIZE + 1 .. $page == $pages ? jobcard : $page * PAGE_SIZE; + user => job_user}, ($page - 1) * PAGE_SIZE + 1 .. ($page == $pages ? jobcard : $page * PAGE_SIZE); $htc->param(log => \@log); }