X-Git-Url: https://sipb.mit.edu/gitweb.cgi/ikiwiki.git/blobdiff_plain/dbb4cc565d4bbc3c25790af744813538b85db01d..30360b3f5349f70dce994f0a6fbc8b71cd7ba708:/plugins/rst diff --git a/plugins/rst b/plugins/rst index 797b686a5..a2d07ebcf 100755 --- a/plugins/rst +++ b/plugins/rst @@ -3,9 +3,6 @@ # # rst — xml-rpc-based ikiwiki plugin to process RST files # -# TODO: the top of this file should be converted to a python library for -# ikiwiki plugins -# # based a little bit on rst.pm by Sergio Talens-Oliag, but only a little bit. :) # # Copyright © martin f. krafft @@ -13,7 +10,7 @@ # __name__ = 'rst' __description__ = 'xml-rpc-based ikiwiki plugin to process RST files' -__version__ = '0.2' +__version__ = '0.3' __author__ = 'martin f. krafft ' __copyright__ = 'Copyright © ' + __author__ __licence__ = 'GPLv2' @@ -21,7 +18,7 @@ __licence__ = 'GPLv2' from docutils.core import publish_parts; from proxy import IkiWikiProcedureProxy -def rst2html(*kwargs): +def rst2html(proxy, *kwargs): # FIXME arguments should be treated as a hash, the order could change # at any time and break this. parts = publish_parts(kwargs[3], writer_name='html', @@ -31,11 +28,15 @@ def rst2html(*kwargs): }) return '\n'.join(parts['html_body'].splitlines()[1:-1]) +def getsetup(proxy, *kwargs): + return 'plugin', { 'safe' : 1, 'rebuild' : 1 } + import sys def debug(s): - sys.stderr.write(__name__ + ':DEBUG:%s' % s) + sys.stderr.write(__name__ + ':DEBUG:%s\n' % s) sys.stderr.flush() proxy = IkiWikiProcedureProxy(__name__, debug_fn=None) -proxy.register_hook('htmlize', rst2html) +proxy.hook('getsetup', getsetup) +proxy.hook('htmlize', rst2html) proxy.run()