* Change htmlize, format, and sanitize hooks to use named parameters.
[ikiwiki] / IkiWiki / Plugin / htmltidy.pm
1 #!/usr/bin/perl
2 # HTML Tidy plugin
3 # requires 'tidy' binary, found in Debian or http://tidy.sf.net/
4 # mostly a proof-of-concept on how to use external filters.
5 # It is particularly useful when the html plugin is used.
6 #
7 # by Faidon Liambotis
8 package IkiWiki::Plugin::htmltidy;
9
10 use warnings;
11 use strict;
12 use IkiWiki;
13 use IPC::Open2;
14
15 sub import { #{{{
16         IkiWiki::hook(type => "sanitize", id => "tidy", call => \&sanitize);
17 } # }}}
18
19 sub sanitize (@) { #{{{
20         my %params=@_;
21
22         my $tries=10;
23         while (1) {
24                 eval {
25                         open2(*IN, *OUT, 'tidy -quiet -asxhtml -utf8 --show-body-only yes --show-warnings no --tidy-mark no');
26                 };
27                 last unless $@;
28                 $tries--;
29                 if ($tries < 1) {
30                         IkiWiki::debug("failed to run tidy: $@");
31                         return $params{content};
32                 }
33         }
34         # open2 doesn't respect "use open ':utf8'"
35         binmode (IN, ':utf8'); 
36         binmode (OUT, ':utf8'); 
37         
38         print OUT $params{content};
39         close OUT;
40
41         local $/ = undef;
42         return <IN>;
43 } # }}}
44
45 1