]> iEval git - gruntmaster-page.git/blobdiff - lib/Gruntmaster/Page.pm
Add article support
[gruntmaster-page.git] / lib / Gruntmaster / Page.pm
index 9fad273e81393639ae9324afad70c89fc332d940..451ed8e3a0a2efbe979f7f510471d56f867500ed 100644 (file)
@@ -3,15 +3,14 @@ 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/;
-use File::Slurp qw/write_file/;
+use File::Path qw/make_path/;
+use File::Slurp qw/read_file 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;
@@ -26,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];
 }
 
 {
@@ -35,6 +33,9 @@ sub declaregen{
        my $contest = qr,(?:ct/$component/)?,;
        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$,;
@@ -45,26 +46,42 @@ sub declaregen{
        declaregen 'Pb::Entry'          => qr,^${contest}pb/$component$,;
 }
 
-sub _generate{
-       my ($path) = @_;
+sub generate{
+       my ($path, $topic) = @_;
        my ($path_noext, $ext) = $path =~ m/^(.*)\.(.*)$/;
-       my $basename = fileparse $path_noext;
+       my ($basename, $directories) = fileparse $path_noext;
+       make_path $directories;
 
        IO::File->new(">$path_noext.var")->close unless -f "$path_noext.var";
        flock my $lockfh = IO::File->new("<$path_noext.var"), LOCK_EX;
        open my $typemap, ">$path_noext.var.new";
        say $typemap "URI: $basename\n";
-       for my $gen (@generators) {
-               my ($regex, $generator) = @$gen;
-               next unless $path_noext =~ $regex;
+
+       my $fill_typemap = sub {
                for my $lang (@{LANGUAGES()}) {
-                       my $page = $generator->($path, $lang);
+                       my $page = $_[0]->($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;
                        say $typemap "URI: $basename.$lang.gz.$ext\nContent-Language: $lang\nContent-Encoding: gzip\nContent-Type: " . CONTENT_TYPES->{$ext} . "\n";
                }
-               last
+       };
+
+       if ($topic eq 'genpage') {
+               for my $gen (@generators) {
+                       my ($regex, $generator) = @$gen;
+                       next unless $path_noext =~ $regex;
+                       $fill_typemap->(sub { $generator->generate($path, $_[0]) });
+                       last
+               }
+       } else {
+               my $get_article = sub {
+                       my $article = read_file "$ENV{GRUNTMASTER_ARTICLE_ROOT}/$basename.$_[0]";
+                       my $title   = read_file "$ENV{GRUNTMASTER_ARTICLE_ROOT}/$basename.$_[0].title";
+                       Gruntmaster::Page::Base::header($_[0], $title) . $article . Gruntmaster::Page::Base::footer($_[0])
+               };
+
+               $fill_typemap->($get_article);
        }
 
        for my $lang (@{LANGUAGES()}) {
@@ -75,8 +92,11 @@ 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};
 }
 
 1;
This page took 0.027528 seconds and 4 git commands to generate.