summaryrefslogtreecommitdiff
path: root/plugins/rst
blob: 449dba415f69195177981459fc1ec0087464edb2 (plain)
  1. #!/usr/bin/python
  2. # -*- coding: utf-8 -*-
  3. #
  4. # rst — xml-rpc-based ikiwiki plugin to process RST files
  5. #
  6. # based a little bit on rst.pm by Sergio Talens-Oliag, but only a little bit. :)
  7. #
  8. # Copyright © martin f. krafft <madduck@madduck.net>
  9. # Released under the terms of the GNU GPL version 2
  10. #
  11. __name__ = 'rst'
  12. __description__ = 'xml-rpc-based ikiwiki plugin to process RST files'
  13. __version__ = '0.3'
  14. __author__ = 'martin f. krafft <madduck@madduck.net>'
  15. __copyright__ = 'Copyright © ' + __author__
  16. __licence__ = 'GPLv2'
  17. from docutils.core import publish_parts;
  18. from proxy import IkiWikiProcedureProxy
  19. def rst2html(proxy, *args):
  20. kwargs = _to_dict(args)
  21. parts = publish_parts(kwargs["content"],
  22. writer_name="html",
  23. settings_overrides = { 'halt_level': 6
  24. , 'file_insertion_enabled': 0
  25. , 'raw_enabled': 1
  26. })
  27. return '\n'.join(parts['html_body'].splitlines()[1:-1])
  28. def _to_dict(args):
  29. # args is a list paired by key, value, so we turn it into a dict
  30. return dict((k, v) for k, v in zip(*[iter(args)]*2))
  31. def getsetup(proxy, *kwargs):
  32. return 'plugin', { 'safe' : 1, 'rebuild' : 1 }
  33. import sys
  34. def debug(s):
  35. sys.stderr.write(__name__ + ':DEBUG:%s\n' % s)
  36. sys.stderr.flush()
  37. proxy = IkiWikiProcedureProxy(__name__, debug_fn=None)
  38. proxy.hook('getsetup', getsetup)
  39. proxy.hook('htmlize', rst2html)
  40. proxy.run()