# $Id: admonitions.py 7681 2013-07-12 07:52:27Z milde $
# Author: David Goodger <goodger@python.org>
# Copyright: This module has been placed in the public domain.
"""
Admonition directives.
"""
__docformat__ = 'reStructuredText'
from docutils.parsers.rst import Directive
from docutils.parsers.rst import states, directives
from docutils.parsers.rst.roles import set_classes
from docutils import nodes
[docs]class BaseAdmonition(Directive):
final_argument_whitespace = True
option_spec = {'class': directives.class_option,
'name': directives.unchanged}
has_content = True
node_class = None
"""Subclasses must set this to the appropriate admonition node class."""
[docs] def run(self):
set_classes(self.options)
self.assert_has_content()
text = '\n'.join(self.content)
admonition_node = self.node_class(text, **self.options)
self.add_name(admonition_node)
if self.node_class is nodes.admonition:
title_text = self.arguments[0]
textnodes, messages = self.state.inline_text(title_text,
self.lineno)
title = nodes.title(title_text, '', *textnodes)
title.source, title.line = (
self.state_machine.get_source_and_line(self.lineno))
admonition_node += title
admonition_node += messages
if not 'classes' in self.options:
admonition_node['classes'] += ['admonition-' +
nodes.make_id(title_text)]
self.state.nested_parse(self.content, self.content_offset,
admonition_node)
return [admonition_node]
[docs]class Admonition(BaseAdmonition):
required_arguments = 1
node_class = nodes.admonition
[docs]class Attention(BaseAdmonition):
node_class = nodes.attention
[docs]class Caution(BaseAdmonition):
node_class = nodes.caution
[docs]class Danger(BaseAdmonition):
node_class = nodes.danger
[docs]class Error(BaseAdmonition):
node_class = nodes.error
[docs]class Hint(BaseAdmonition):
node_class = nodes.hint
[docs]class Important(BaseAdmonition):
node_class = nodes.important
[docs]class Note(BaseAdmonition):
node_class = nodes.note
[docs]class Tip(BaseAdmonition):
node_class = nodes.tip
[docs]class Warning(BaseAdmonition):
node_class = nodes.warning