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;