view piecrust/formatting/smartypantsformatter.py @ 486:aae241804096

themes: Don't fixup template directories, it's actually better as-is. Prepending `theme/` is not too much trouble, and directories without that are useful for handling possible user overrides.
author Ludovic Chabant <ludovic@chabant.com>
date Wed, 22 Jul 2015 20:00:14 -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)