X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FPage.pm;h=a07a10213cd65bf6aa142b2192693c28c8b63ac9;hb=12f5cac9d95e04bb84e47952dd938031557b57c4;hp=5c63f642174ff4046837cfe57aac8df05ee71ad3;hpb=42546e6c1b709dc4c8d8e7048becc14278b6cdf0;p=plack-app-gruntmaster.git
diff --git a/lib/Gruntmaster/Page.pm b/lib/Gruntmaster/Page.pm
index 5c63f64..a07a102 100644
--- a/lib/Gruntmaster/Page.pm
+++ b/lib/Gruntmaster/Page.pm
@@ -4,11 +4,13 @@ use 5.014000;
use strict;
use warnings;
use parent qw/Exporter/;
-our @EXPORT_OK = qw/generate header footer/;
+our @EXPORT_OK = qw/generate/;
+use Fcntl qw/:flock/;
use File::Basename qw/fileparse/;
use File::Slurp qw/write_file/;
use IO::Compress::Gzip qw/gzip/;
+use IO::File;
our $VERSION = '0.001';
our @generators;
@@ -19,44 +21,6 @@ use constant CONTENT_TYPES => {
txt => 'text/plain; charset=UTF-8',
};
-my %header_templates = (
- en => <<'HTML',
-
-
TITLE_GOES_HERE
-
-
-
-
-
-
-iEval
-TITLE_GOES_HERE
-
-
-
-HTML
-);
-
-my %footer_templates = (
- en => <<'HTML',
-
-
-HTML
-);
-
-sub header{
- my ($language, $title) = @_;
- $header_templates{$language} =~ s/TITLE_GOES_HERE/$title/ger;
-}
-
-sub footer{
- $footer_templates{$_[0]};
-}
-
sub declaregen{
my ($generator, $regex) = @_;
$generator = "Gruntmaster::Page::$generator";
@@ -65,31 +29,47 @@ sub declaregen{
push @generators, [$regex, $gensub];
}
-declaregen Index => qr'^index$';
-declaregen Log => qr'^log/index$';
-declaregen 'Log::Entry' => qr'^log/.*/index$';
-declaregen Submit => qr'^submit$';
-declaregen Pb => qr'^pb/index$';
-declaregen 'Pb::Entry' => qr'^pb/.*/index$';
+{
+ my $component = qr'[^/]+';
+ my $contest = qr,(?:ct/$component/)?,;
+ declaregen Index => qr,^index$,;
+ declaregen Ct => qr,^ct/index$,;
+ declaregen 'Ct::Entry' => qr,^ct/$component/index$,;
+ declaregen St => qr,^ct/$component/log/st$,;
+ declaregen Learn => qr,^learn$,;
+ declaregen Log => qr,^${contest}log/index$,;
+ declaregen 'Log::Entry' => qr,^${contest}log/$component/index$,;
+ declaregen Submit => qr,^${contest}submit$,;
+ declaregen Pb => qr,^${contest}pb/index$,;
+ declaregen 'Pb::Entry' => qr,^${contest}pb/$component/index$,;
+}
sub generate{
my ($path) = @_;
my ($path_noext, $ext) = $path =~ m/^(.*)\.(.*)$/;
my $basename = fileparse $path_noext;
- open my $typemap, ">$path_noext.var";
+ 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;
for my $lang (@{LANGUAGES()}) {
my $page = $generator->($path, $lang);
- write_file "$path_noext.$lang.$ext", $page;
+ 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", Minimal => 1;
+ 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";
}
}
+
+ for my $lang(@{LANGUAGES()}) {
+ rename "$path_noext.$lang.$ext.new", "$path_noext.$lang.$ext";
+ rename "$path_noext.$lang.gz.$ext.new", "$path_noext.$lang.gz.$ext";
+ }
+ rename "$path_noext.var.new", "$path_noext.var";
close $typemap;
}