3 # Licensed under the GPL v2 or greater
4 # Copyright (C) 2008 by Axel Beckert <abe@deuxchevaux.org>
6 # TODO: Make a switch to allow both HTML export routines of hnb
7 # (`export_html` and `export_htmlcss`) to be used.
9 package IkiWiki
::Plugin
::hnb
;
14 use File
::Temp
qw(:mktemp);
17 hook
(type
=> "getsetup", id
=> "hnb", call
=> \
&getsetup
);
18 hook
(type
=> "htmlize", id
=> "hnb", call
=> \
&htmlize
);
25 rebuild
=> 1, # format plugin
33 # hnb outputs version number etc. every time to STDOUT, so
34 # using files makes it easier to seprarate.
36 my ($infh, $tmpin) = mkstemp
( "/tmp/ikiwiki-hnbin.XXXXXXXXXX" );
37 my ($outfh, $tmpout) = mkstemp
( "/tmp/ikiwiki-hnbout.XXXXXXXXXX" );
39 open(TMP
, '>', $tmpin) or die "Can't write to $tmpin: $!";
40 print TMP
$params{content
};
43 system("hnb '$tmpin' 'go root' 'export_html $tmpout' > /dev/null");
46 open(TMP
, '<', $tmpout) or die "Can't read from $tmpout: $!";
52 $ret =~ s/.*<body>//si;
53 $ret =~ s/<body>.*//si;