Admonition extension for Python-Markdown.
Adds rST-style admonitions. Inspired by rST feature with the same name.
See https://pythonhosted.org/Markdown/extensions/admonition.html
for documentation.
Original code Copyright Tiago Serafim.
All changes Copyright The Python Markdown Project
License: BSD
Classes
AdmonitionExtension(*args, **kwargs)
Bases: Extension
Admonition extension for Python-Markdown.
Initiate Extension and set up configs.
Source code in pyrevitlib/pyrevit/coreutils/markdown/extensions/__init__.py
| def __init__(self, *args, **kwargs):
"""Initiate Extension and set up configs."""
# check for configs arg for backward compat.
# (there only ever used to be one so we use arg[0])
if len(args):
if args[0] is not None:
self.setConfigs(args[0])
warnings.warn('Extension classes accepting positional args is '
'pending Deprecation. Each setting should be '
'passed into the Class as a keyword. Positional '
'args are deprecated and will raise '
'an error in version 2.7. See the Release Notes for '
'Python-Markdown version 2.6 for more info.',
DeprecationWarning)
# check for configs kwarg for backward compat.
if 'configs' in kwargs.keys():
if kwargs['configs'] is not None:
self.setConfigs(kwargs.pop('configs', {}))
warnings.warn('Extension classes accepting a dict on the single '
'keyword "config" is pending Deprecation. Each '
'setting should be passed into the Class as a '
'keyword directly. The "config" keyword is '
'deprecated and raise an error in '
'version 2.7. See the Release Notes for '
'Python-Markdown version 2.6 for more info.',
DeprecationWarning)
# finally, use kwargs
self.setConfigs(kwargs)
|
Attributes
config = {}
class-attribute
instance-attribute
Functions
getConfig(key, default='')
Return a setting for the given key or an empty string.
Source code in pyrevitlib/pyrevit/coreutils/markdown/extensions/__init__.py
| def getConfig(self, key, default=''):
"""Return a setting for the given key or an empty string."""
if key in self.config:
return self.config[key][0]
else:
return default
|
getConfigs()
Return all configs settings as a dict.
Source code in pyrevitlib/pyrevit/coreutils/markdown/extensions/__init__.py
| def getConfigs(self):
"""Return all configs settings as a dict."""
return dict([(key, self.getConfig(key)) for key in self.config.keys()])
|
getConfigInfo()
Return all config descriptions as a list of tuples.
Source code in pyrevitlib/pyrevit/coreutils/markdown/extensions/__init__.py
| def getConfigInfo(self):
"""Return all config descriptions as a list of tuples."""
return [(key, self.config[key][1]) for key in self.config.keys()]
|
setConfig(key, value)
Set a config setting for key
with the given value
.
Source code in pyrevitlib/pyrevit/coreutils/markdown/extensions/__init__.py
| def setConfig(self, key, value):
"""Set a config setting for `key` with the given `value`."""
if isinstance(self.config[key][0], bool):
value = parseBoolValue(value)
if self.config[key][0] is None:
value = parseBoolValue(value, preserve_none=True)
self.config[key][0] = value
|
setConfigs(items)
Set multiple config settings given a dict or list of tuples.
Source code in pyrevitlib/pyrevit/coreutils/markdown/extensions/__init__.py
| def setConfigs(self, items):
"""Set multiple config settings given a dict or list of tuples."""
if hasattr(items, 'items'):
# it's a dict
items = items.items()
for key, value in items:
self.setConfig(key, value)
|
extendMarkdown(md, md_globals)
Add Admonition to Markdown instance.
Source code in pyrevitlib/pyrevit/coreutils/markdown/extensions/admonition.py
| def extendMarkdown(self, md, md_globals):
"""Add Admonition to Markdown instance."""
md.registerExtension(self)
md.parser.blockprocessors.add('admonition',
AdmonitionProcessor(md.parser),
'_begin')
|
AdmonitionProcessor(parser)
Bases: BlockProcessor
Admonition processor.
Source code in pyrevitlib/pyrevit/coreutils/markdown/blockprocessors.py
| def __init__(self, parser):
self.parser = parser
self.tab_length = parser.markdown.tab_length
|
Attributes
parser = parser
instance-attribute
tab_length = parser.markdown.tab_length
instance-attribute
CLASSNAME = 'admonition'
class-attribute
instance-attribute
CLASSNAME_TITLE = 'admonition-title'
class-attribute
instance-attribute
RE = re.compile('(?:^|\\n)!!!\\ ?([\\w\\-]+)(?:\\ "(.*?)")?')
class-attribute
instance-attribute
Functions
lastChild(parent)
Return the last child of an etree element.
Source code in pyrevitlib/pyrevit/coreutils/markdown/blockprocessors.py
| def lastChild(self, parent):
"""Return the last child of an etree element."""
if len(parent):
return parent[-1]
else:
return None
|
detab(text)
Remove a tab from the front of each line of the given text.
Source code in pyrevitlib/pyrevit/coreutils/markdown/blockprocessors.py
| def detab(self, text):
"""Remove a tab from the front of each line of the given text."""
newtext = []
lines = text.split('\n')
for line in lines:
if line.startswith(' '*self.tab_length):
newtext.append(line[self.tab_length:])
elif not line.strip():
newtext.append('')
else:
break
return '\n'.join(newtext), '\n'.join(lines[len(newtext):])
|
looseDetab(text, level=1)
Remove a tab from front of lines but allowing dedented lines.
Source code in pyrevitlib/pyrevit/coreutils/markdown/blockprocessors.py
| def looseDetab(self, text, level=1):
"""Remove a tab from front of lines but allowing dedented lines."""
lines = text.split('\n')
for i in range(len(lines)):
if lines[i].startswith(' '*self.tab_length*level):
lines[i] = lines[i][self.tab_length*level:]
return '\n'.join(lines)
|
test(parent, block)
Source code in pyrevitlib/pyrevit/coreutils/markdown/extensions/admonition.py
| def test(self, parent, block):
sibling = self.lastChild(parent)
return self.RE.search(block) or \
(block.startswith(' ' * self.tab_length) and sibling is not None and
sibling.get('class', '').find(self.CLASSNAME) != -1)
|
run(parent, blocks)
Source code in pyrevitlib/pyrevit/coreutils/markdown/extensions/admonition.py
| def run(self, parent, blocks):
sibling = self.lastChild(parent)
block = blocks.pop(0)
m = self.RE.search(block)
if m:
block = block[m.end() + 1:] # removes the first line
block, theRest = self.detab(block)
if m:
klass, title = self.get_class_and_title(m)
div = etree.SubElement(parent, 'div')
div.set('class', '%s %s' % (self.CLASSNAME, klass))
if title:
p = etree.SubElement(div, 'p')
p.text = title
p.set('class', self.CLASSNAME_TITLE)
else:
div = sibling
self.parser.parseChunk(div, block)
if theRest:
# This block contained unindented line(s) after the first indented
# line. Insert these lines as the first block of the master blocks
# list for future processing.
blocks.insert(0, theRest)
|
get_class_and_title(match)
Source code in pyrevitlib/pyrevit/coreutils/markdown/extensions/admonition.py
| def get_class_and_title(self, match):
klass, title = match.group(1).lower(), match.group(2)
if title is None:
# no title was provided, use the capitalized classname as title
# e.g.: `!!! note` will render
# `<p class="admonition-title">Note</p>`
title = klass.capitalize()
elif title == '':
# an explicit blank title should not be rendered
# e.g.: `!!! warning ""` will *not* render `p` with a title
title = None
return klass, title
|
Functions
makeExtension(*args, **kwargs)
Source code in pyrevitlib/pyrevit/coreutils/markdown/extensions/admonition.py
| def makeExtension(*args, **kwargs):
return AdmonitionExtension(*args, **kwargs)
|