aboutsummaryrefslogtreecommitdiff
path: root/plugins/rst
blob: 797b686a5da681f4c9300eee2ed78482fe19ed19 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#!/usr/bin/python
# -*- coding: utf-8 -*-
#
# 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 <madduck@madduck.net>
# Released under the terms of the GNU GPL version 2
#
__name__ = 'rst'
__description__ = 'xml-rpc-based ikiwiki plugin to process RST files'
__version__ = '0.2'
__author__ = 'martin f. krafft <madduck@madduck.net>'
__copyright__ = 'Copyright © ' + __author__
__licence__ = 'GPLv2'

from docutils.core import publish_parts;
from proxy import IkiWikiProcedureProxy

def rst2html(*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',
                          settings_overrides = { 'halt_level': 6
                                               , 'file_insertion_enabled': 0
                                               , 'raw_enabled': 1
                                               })
    return '\n'.join(parts['html_body'].splitlines()[1:-1])

import sys
def debug(s):
    sys.stderr.write(__name__ + ':DEBUG:%s' % s)
    sys.stderr.flush()

proxy = IkiWikiProcedureProxy(__name__, debug_fn=None)
proxy.register_hook('htmlize', rst2html)
proxy.run()