2 # -*- coding: utf-8 -*-
4 # rst — xml-rpc-based ikiwiki plugin to process RST files
6 # based a little bit on rst.pm by Sergio Talens-Oliag, but only a little bit. :)
8 # Copyright © martin f. krafft <madduck@madduck.net>
9 # Released under the terms of the GNU GPL version 2
12 __description__ = 'xml-rpc-based ikiwiki plugin to process RST files'
14 __author__ = 'martin f. krafft <madduck@madduck.net>'
15 __copyright__ = 'Copyright © ' + __author__
18 from docutils.core import publish_parts;
19 from proxy import IkiWikiProcedureProxy
21 def rst2html(proxy, *args):
22 kwargs = _to_dict(args)
23 parts = publish_parts(kwargs["content"],
25 settings_overrides = { 'halt_level': 6
26 , 'file_insertion_enabled': 0
29 return '\n'.join(parts['html_body'].splitlines()[1:-1])
32 # args is a list paired by key, value, so we turn it into a dict
33 return dict((k, v) for k, v in zip(*[iter(args)]*2))
35 def getsetup(proxy, *kwargs):
36 return 'plugin', { 'safe' : 1, 'rebuild' : 1 }
40 sys.stderr.write(__name__ + ':DEBUG:%s\n' % s)
43 proxy = IkiWikiProcedureProxy(__name__, debug_fn=None)
44 proxy.hook('getsetup', getsetup)
45 proxy.hook('htmlize', rst2html)