summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorintrigeri <intrigeri@boum.org>2008-10-05 19:42:43 +0200
committerintrigeri <intrigeri@boum.org>2008-10-18 15:49:07 +0200
commit1b5f610a974bedd98b4feeaf566f6ad2eeb6acab (patch)
tree70036f968a56e0cba4f7ac5ab7a77032d8246006
parent75fc44ce2fa43c984a1920f40d97631ace84d4f6 (diff)
po plugin: convert PO to master page's type in filter hook
Master page's type htmlize hook should also be run in po's htmlize hook, but let's proceed step by step. Signed-off-by: intrigeri <intrigeri@boum.org>
-rw-r--r--IkiWiki/Plugin/po.pm40
1 files changed, 35 insertions, 5 deletions
diff --git a/IkiWiki/Plugin/po.pm b/IkiWiki/Plugin/po.pm
index fb4741cd4..62632e1df 100644
--- a/IkiWiki/Plugin/po.pm
+++ b/IkiWiki/Plugin/po.pm
@@ -1,11 +1,15 @@
#!/usr/bin/perl
# .po as a wiki page type
+# inspired by the GPL'd po4a-translate,
+# which is Copyright 2002, 2003, 2004 by Martin Quinson (mquinson#debian.org)
package IkiWiki::Plugin::po;
use warnings;
use strict;
use IkiWiki 2.00;
use Encode;
+use Locale::Po4a::Chooser;
+use File::Temp;
sub import {
hook(type => "getsetup", id => "po", call => \&getsetup);
@@ -49,22 +53,48 @@ sub targetpage (@) { #{{{
}
} #}}}
-# We use filter to convert PO to HTML, since the other plugins might do harm to it.
+# We use filter to convert PO to the master page's type,
+# since other plugins should not work on PO files
sub filter (@) { #{{{
my %params = @_;
+ my $page = $params{page};
my $content = decode_utf8(encode_utf8($params{content}));
- if (defined $pagesources{$params{page}} && $pagesources{$params{page}} =~ /\.po$/) {
- $content = "<pre>" . $content . "</pre>";
+ # 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)) {
+ return $content;
}
+ my ($masterpage, $lang) = ($page =~ /(.*)[.]([a-z]{2})$/);
+ my $file=srcfile(exists $params{file} ? $params{file} : $IkiWiki::pagesources{$page});
+ my $masterfile = srcfile($pagesources{$masterpage});
+ my (@pos,@masters);
+ push @pos,$file;
+ push @masters,$masterfile;
+ my %options = (
+ "markdown" => (pagetype($masterfile) eq 'mdwn') ? 1 : 0,
+ );
+ my $doc=Locale::Po4a::Chooser::new('text',%options);
+ $doc->process(
+ 'po_in_name' => \@pos,
+ 'file_in_name' => \@masters,
+ 'file_in_charset' => 'utf-8',
+ 'file_out_charset' => 'utf-8',
+ ) or error("[po/filter:$file]: failed to translate");
+ my ($percent,$hit,$queries) = $doc->stats();
+ my $tmpfh = File::Temp->new(TEMPLATE => "/tmp/ikiwiki-po-filter-out.XXXXXXXXXX");
+ my $tmpout = $tmpfh->filename;
+ $doc->write($tmpout) or error("[po/filter:$file] could not write $tmpout");
+ $content = readfile($tmpout) or error("[po/filter:$file] could not read $tmpout");
return $content;
} #}}}
-# We need this to register the .po file extension
sub htmlize (@) { #{{{
my %params=@_;
- return $params{content};
+ my $content = $params{content};
+ # FIXME: run master page's type htmlize hook
+ return $content;
} #}}}
package IkiWiki::PageSpec;