X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FPage.pm;h=eedbec54e17d2e865b8ec4cfe6ddc96224d2ed03;hb=2ee6edcf1262d2a3059dd0859d9b750c4a2ff02b;hp=953d8ae4ab6d78c181d558cff9de3884762f4901;hpb=ea6ce64dda40ffaa82846103d02a9c7668bd2a44;p=plack-app-gruntmaster.git diff --git a/lib/Gruntmaster/Page.pm b/lib/Gruntmaster/Page.pm index 953d8ae..eedbec5 100644 --- a/lib/Gruntmaster/Page.pm +++ b/lib/Gruntmaster/Page.pm @@ -3,8 +3,6 @@ package Gruntmaster::Page; use 5.014000; use strict; use warnings; -use parent qw/Exporter/; -our @EXPORT_OK = qw/generate _generate/; use Fcntl qw/:flock/; use File::Basename qw/fileparse/; @@ -12,7 +10,7 @@ use File::Path qw/make_path/; use File::Slurp qw/write_file/; use IO::Compress::Gzip qw/gzip/; use IO::File; -use Gruntmaster::Data qw/PUBLISH/; +use Gruntmaster::Data; our $VERSION = '0.001'; our @generators; @@ -27,8 +25,7 @@ sub declaregen{ my ($generator, $regex) = @_; $generator = "Gruntmaster::Page::$generator"; eval "require $generator"; - my $gensub = $generator->can('generate') or die "No such generator: $generator"; - push @generators, [$regex, $gensub]; + push @generators, [$regex, $generator]; } { @@ -37,6 +34,8 @@ sub declaregen{ declaregen Index => qr,^index$,; declaregen Learn => qr,^learn$,; declaregen Account => qr,^account$,; + declaregen Us => qr,^us/index$,; + declaregen 'Us::Entry' => qr,^us/$component$,; declaregen Ct => qr,^ct/index$,; declaregen 'Ct::Entry' => qr,^ct/$component/index$,; declaregen St => qr,^ct/$component/log/st$,; @@ -47,7 +46,7 @@ sub declaregen{ declaregen 'Pb::Entry' => qr,^${contest}pb/$component$,; } -sub _generate{ +sub generate{ my ($path) = @_; my ($path_noext, $ext) = $path =~ m/^(.*)\.(.*)$/; my ($basename, $directories) = fileparse $path_noext; @@ -61,7 +60,7 @@ sub _generate{ my ($regex, $generator) = @$gen; next unless $path_noext =~ $regex; for my $lang (@{LANGUAGES()}) { - my $page = $generator->($path, $lang); + my $page = $generator->generate($path, $lang); write_file "$path_noext.$lang.$ext.new", $page; say $typemap "URI: $basename.$lang.$ext\nContent-Language: $lang\nContent-Type: " . CONTENT_TYPES->{$ext} . "\n"; gzip \$page => "$path_noext.$lang.gz.$ext.new", Minimal => 1; @@ -78,8 +77,15 @@ sub _generate{ close $typemap; } -sub generate{ - PUBLISH 'genpage', shift; +sub gensrc{ + my ($job) = @_; + my $ext = job_extension $job; + make_path "log/src/"; + write_file "log/src/$job.$ext", job_inmeta($job)->{files}{prog}{content}; +} + +sub genarticle{ + } 1;