diff options
author | joey <joey@0fa5a96a-9a0e-0410-b3b2-a0fd24251071> | 2006-08-17 20:39:00 +0000 |
---|---|---|
committer | joey <joey@0fa5a96a-9a0e-0410-b3b2-a0fd24251071> | 2006-08-17 20:39:00 +0000 |
commit | 480a49af4755ae42d409ed351f99219cee846638 (patch) | |
tree | 5fd5e1c3ed9621b4a1b14fec0e79cf60f239cedd | |
parent | 24fcf2b97d86debeb27ab4ab46a6bc0a2f23f2b2 (diff) |
* Catch failing IPC::Open2 in tidy plugin and retry in case this is a
transient failure to fork (which I've seen happen in the wild).
-rw-r--r-- | IkiWiki/Plugin/htmltidy.pm | 13 | ||||
-rw-r--r-- | debian/changelog | 4 |
2 files changed, 15 insertions, 2 deletions
diff --git a/IkiWiki/Plugin/htmltidy.pm b/IkiWiki/Plugin/htmltidy.pm index e39297319..eb8f9d3d3 100644 --- a/IkiWiki/Plugin/htmltidy.pm +++ b/IkiWiki/Plugin/htmltidy.pm @@ -17,7 +17,18 @@ sub import { #{{{ } # }}} sub sanitize ($) { #{{{ - open2(*IN, *OUT, 'tidy -quiet -asxhtml -utf8 --show-body-only yes --show-warnings no --tidy-mark no') or return shift; + my $tries=10; + while (1) { + eval { + open2(*IN, *OUT, 'tidy -quiet -asxhtml -utf8 --show-body-only yes --show-warnings no --tidy-mark no'); + }; + last unless $@; + $tries--; + if ($tries < 1) { + IkiWiki::debug("failed to run tidy: $@"); + return shift; + } + } # open2 doesn't respect "use open ':utf8'" binmode (IN, ':utf8'); binmode (OUT, ':utf8'); diff --git a/debian/changelog b/debian/changelog index 7ed15dcb1..a302b9ecf 100644 --- a/debian/changelog +++ b/debian/changelog @@ -4,8 +4,10 @@ ikiwiki (1.20) UNRELEASED; urgency=low Since these can easily become part of other people's websites, they should be under as permissive a license as possible. * Add --syslog config option, to log to the syslog. + * Catch failing IPC::Open2 in tidy plugin and retry in case this is a + transient failure to fork (which I've seen happen in the wild). - -- Joey Hess <joeyh@debian.org> Wed, 16 Aug 2006 17:07:35 -0400 + -- Joey Hess <joeyh@debian.org> Thu, 17 Aug 2006 14:43:02 -0400 ikiwiki (1.19) unstable; urgency=low |