--- /dev/null
+#!/usr/bin/perl
+# outline markup
+package IkiWiki::Plugin::otl;
+
+use warnings;
+use strict;
+use IkiWiki;
+use IPC::Open2;
+
+sub import { #{{{
+ IkiWiki::hook(type => "htmlize", id => "otl", call => \&htmlize);
+} # }}}
+
+sub htmlize ($) { #{{{
+ my $tries=10;
+ while (1) {
+ eval {
+ open2(*IN, *OUT, 'otl2html -S /dev/null -T /dev/stdin');
+ };
+ last unless $@;
+ $tries--;
+ if ($tries < 1) {
+ IkiWiki::debug("failed to run otl2html: $@");
+ return shift;
+ }
+ }
+ # open2 doesn't respect "use open ':utf8'"
+ binmode (IN, ':utf8');
+ binmode (OUT, ':utf8');
+
+ print OUT shift;
+ close OUT;
+
+ local $/ = undef;
+ my $ret=<IN>;
+ $ret=~s/.*<body>//s;
+ $ret=~s/<body>.*//s;
+ return $ret;
+} # }}}
+
+1
use warnings;
use strict;
+use IkiWiki;
use Text::WikiFormat;
sub import { #{{{
* Implemented better cycle detection in the inline plugin; nested inlines
will now work.
* Add a map plugin contributed by Alessandro Dotti Contra.
+ * Add otl format plugin, which handles files as created by vimoutliner.
- -- Joey Hess <joeyh@debian.org> Fri, 18 Aug 2006 12:10:37 -0400
+ -- Joey Hess <joeyh@debian.org> Fri, 18 Aug 2006 17:27:38 -0400
ikiwiki (1.20) unstable; urgency=low
--- /dev/null
+This plugin allows ikiwiki to process `.otl` outline files, as created by
+[vimoutliner](http://www.vimoutliner.org/). To use it, you need to have
+vimoutliner installed, since it uses the `otl2html` program.
+
+This plugin is included in ikiwiki, but is not enabled by default.
+
+[[tag type/format]]