hook(type => "getsetup", id => "po", call => \&getsetup);
hook(type => "targetpage", id => "po", call => \&targetpage);
hook(type => "filter", id => "po", call => \&filter);
+ hook(type => "preprocess", id => "translatable", call => \&preprocess_translatable);
hook(type => "htmlize", id => "po", call => \&htmlize);
}
my $page=$params{page};
my $ext=$params{ext};
- if (IkiWiki::PageSpec::match_istranslation($page, $page)) {
+ if (pagespec_match($page,"istranslation()")) {
my ($masterpage, $lang) = ($page =~ /(.*)[.]([a-z]{2})$/);
if (! $config{usedirs} || $page eq 'index') {
return $masterpage . "." . $lang . "." . $ext;
# decide if this is a PO file that should be converted into a translated document,
# and perform various sanity checks
- if (! IkiWiki::PageSpec::match_istranslation($page, $page)) {
+ if (! pagespec_match($page, "istranslation()")) {
return $content;
}
return $content;
} #}}}
+sub preprocess_translatable (@) { #{{{
+ my %params = @_;
+ my $match = exists $params{match} ? $params{match} : $params{page};
+
+ $pagestate{$params{page}}{po_translatable}{$match}=1;
+
+ return "" if ($params{silent} && IkiWiki::yesno($params{silent}));
+ return sprintf(gettext("pages %s set as translatable"), $params{match});
+
+} #}}}
+
sub htmlize (@) { #{{{
my %params=@_;
my $page = $params{page};