Mercurial > piecrust2
view piecrust/formatting/markdownformatter.py @ 979:45ad976712ec
tests: Big push to get the tests to pass again.
- Lots of fixes everywhere in the code.
- Try to handle debug logging in the multiprocessing worker pool when running in pytest. Not perfect, but usable for now.
- Replace all `.md` test files with `.html` since now a auto-format extension always sets the format.
- Replace `out` with `outfiles` in most places since now blog archives are added to the bake output and I don't want to add expected outputs for blog archives everywhere.
author | Ludovic Chabant <ludovic@chabant.com> |
---|---|
date | Sun, 29 Oct 2017 22:51:57 -0700 |
parents | 370e74941d32 |
children | 8adc27285d93 |
line wrap: on
line source
from piecrust.formatting.base import Formatter class MarkdownFormatter(Formatter): FORMAT_NAMES = ['markdown', 'mdown', 'md'] OUTPUT_FORMAT = 'html' def __init__(self): super(MarkdownFormatter, self).__init__() self._formatter = None def render(self, format_name, txt): assert format_name in self.FORMAT_NAMES self._ensureInitialized() return self._formatter.reset().convert(txt) def _ensureInitialized(self): if self._formatter is not None: return config = self.app.config.get('markdown') if config is None: config = {} elif not isinstance(config, dict): raise Exception("The `markdown` configuration setting must be " "a dictionary.") extensions = config.get('extensions', []) if isinstance(extensions, str): extensions = [e.strip() for e in extensions.split(',')] # Compatibility with PieCrust 1.x if config.get('use_markdown_extra'): extensions.append('extra') extension_configs = config.get('extension_configs', {}) from markdown import Markdown self._formatter = Markdown(extensions=extensions, extension_configs=extension_configs)