Photos
Blog
Projects
vanrenterghem.biz
projects
/
git.ikiwiki.info.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
typo
[git.ikiwiki.info.git]
/
IkiWiki
/
Plugin
/
htmltidy.pm
diff --git
a/IkiWiki/Plugin/htmltidy.pm
b/IkiWiki/Plugin/htmltidy.pm
index d9aaba4ca1f4e7c6d3ed631089584071df5a2b3f..da77e60f1cb6198278e87897522fd74b553f95e9 100644
(file)
--- a/
IkiWiki/Plugin/htmltidy.pm
+++ b/
IkiWiki/Plugin/htmltidy.pm
@@
-9,33
+9,48
@@
package IkiWiki::Plugin::htmltidy;
use warnings;
use strict;
use warnings;
use strict;
-use IkiWiki
2
.00;
+use IkiWiki
3
.00;
use IPC::Open2;
use IPC::Open2;
-sub import {
#{{{
+sub import {
hook(type => "getsetup", id => "tidy", call => \&getsetup);
hook(type => "sanitize", id => "tidy", call => \&sanitize);
hook(type => "getsetup", id => "tidy", call => \&getsetup);
hook(type => "sanitize", id => "tidy", call => \&sanitize);
-} # }}}
+ hook(type => "checkconfig", id => "tidy", call => \&checkconfig);
+}
-sub getsetup () {
#{{{
+sub getsetup () {
return
plugin => {
safe => 1,
rebuild => undef,
},
return
plugin => {
safe => 1,
rebuild => undef,
},
-} #}}}
+ htmltidy => {
+ type => "string",
+ description => "tidy command line",
+ safe => 0, # path
+ rebuild => undef,
+ },
+}
+
+sub checkconfig () {
+ if (! defined $config{htmltidy}) {
+ $config{htmltidy}="tidy -quiet -asxhtml -utf8 --show-body-only yes --show-warnings no --tidy-mark no --markup yes";
+ }
+}
-sub sanitize (@) {
#{{{
+sub sanitize (@) {
my %params=@_;
my %params=@_;
+ return $params{content} unless defined $config{htmltidy};
+
my $pid;
my $sigpipe=0;
$SIG{PIPE}=sub { $sigpipe=1 };
my $pid;
my $sigpipe=0;
$SIG{PIPE}=sub { $sigpipe=1 };
- $pid=open2(*IN, *OUT,
'tidy -quiet -asxhtml -utf8 --show-body-only yes --show-warnings no --tidy-mark no --markup yes'
);
-
+ $pid=open2(*IN, *OUT,
"$config{htmltidy} 2>/dev/null"
);
+
# open2 doesn't respect "use open ':utf8'"
binmode (IN, ':utf8');
# open2 doesn't respect "use open ':utf8'"
binmode (IN, ':utf8');
- binmode (OUT, ':utf8');
+ binmode (OUT, ':utf8');
print OUT $params{content};
close OUT;
print OUT $params{content};
close OUT;
@@
-46,9
+61,11
@@
sub sanitize (@) { #{{{
waitpid $pid, 0;
$SIG{PIPE}="DEFAULT";
waitpid $pid, 0;
$SIG{PIPE}="DEFAULT";
- return $params{content} if $sigpipe;
+ if ($sigpipe || ! defined $ret) {
+ return gettext("htmltidy failed to parse this html");
+ }
return $ret;
return $ret;
-}
# }}}
+}
1
1