view piecrust/formatting/smartypantsformatter.py @ 407:bd56d9acd6ef

debug: Add support for more attributes for the debug info. * `debug_render_not_empty`: don't render an "empty" label if not attributes or items have been rendered for an object. * `debug_render_doc_dynamic`: render dynamic doc-string.
author Ludovic Chabant <ludovic@chabant.com>
date Mon, 25 May 2015 18:36:44 -0700
parents fdb08d986384
children 370e74941d32
line wrap: on
line source

import smartypants
from piecrust.formatting.base import Formatter, PRIORITY_LAST


class SmartyPantsFormatter(Formatter):
    FORMAT_NAMES = ['html']
    OUTPUT_FORMAT = 'html'

    def __init__(self):
        super(SmartyPantsFormatter, self).__init__()
        self.priority = PRIORITY_LAST

    def initialize(self, app):
        super(SmartyPantsFormatter, self).initialize(app)
        self.enabled = (
                app.config.get('smartypants/enable') or
                app.config.get('smartypants/enabled'))

    def render(self, format_name, txt):
        assert format_name == 'html'
        return smartypants.smartypants(txt)