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);
21 sub getsetup () { #{{{
25 rebuild => 1, # format plugin
29 sub htmlize (@) { #{{{
32 # hnb outputs version number etc. every time to STDOUT, so
33 # using files makes it easier to seprarate.
35 my $tmpin = mkstemp( "/tmp/ikiwiki-hnbin.XXXXXXXXXX" );
36 my $tmpout = mkstemp( "/tmp/ikiwiki-hnbout.XXXXXXXXXX" );
38 open(TMP, '>', $tmpin) or die "Can't write to $tmpin: $!";
39 print TMP $params{content};
42 system("hnb '$tmpin' 'go root' 'export_html $tmpout' > /dev/null");
45 open(TMP, '<', $tmpout) or die "Can't read from $tmpout: $!";
51 $ret =~ s/.*<body>//si;
52 $ret =~ s/<body>.*//si;