buildframework/helium/external/python/lib/common/docutils-0.5-py2.5.egg/docutils/parsers/rst/directives/body.py
author wbernard
Wed, 23 Dec 2009 19:29:07 +0200
changeset 179 d8ac696cc51f
permissions -rw-r--r--
helium_7.0-r14027
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
179
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
     1
# $Id: body.py 4667 2006-07-12 21:40:56Z wiemann $
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
     2
# Author: David Goodger <goodger@python.org>
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
     3
# Copyright: This module has been placed in the public domain.
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
     4
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
     5
"""
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
     6
Directives for additional body elements.
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
     7
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
     8
See `docutils.parsers.rst.directives` for API details.
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
     9
"""
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    10
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    11
__docformat__ = 'reStructuredText'
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    12
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    13
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    14
import sys
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    15
from docutils import nodes
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    16
from docutils.parsers.rst import Directive
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    17
from docutils.parsers.rst import directives
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    18
from docutils.parsers.rst.roles import set_classes
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    19
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    20
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    21
class BasePseudoSection(Directive):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    22
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    23
    required_arguments = 1
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    24
    optional_arguments = 0
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    25
    final_argument_whitespace = True
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    26
    option_spec = {'class': directives.class_option}
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    27
    has_content = True
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    28
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    29
    node_class = None
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    30
    """Node class to be used (must be set in subclasses)."""
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    31
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    32
    def run(self):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    33
        if not (self.state_machine.match_titles
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    34
                or isinstance(self.state_machine.node, nodes.sidebar)):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    35
            raise self.error('The "%s" directive may not be used within '
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    36
                             'topics or body elements.' % self.name)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    37
        self.assert_has_content()
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    38
        title_text = self.arguments[0]
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    39
        textnodes, messages = self.state.inline_text(title_text, self.lineno)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    40
        titles = [nodes.title(title_text, '', *textnodes)]
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    41
        # Sidebar uses this code.
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    42
        if self.options.has_key('subtitle'):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    43
            textnodes, more_messages = self.state.inline_text(
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    44
                self.options['subtitle'], self.lineno)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    45
            titles.append(nodes.subtitle(self.options['subtitle'], '',
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    46
                                         *textnodes))
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    47
            messages.extend(more_messages)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    48
        text = '\n'.join(self.content)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    49
        node = self.node_class(text, *(titles + messages))
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    50
        node['classes'] += self.options.get('class', [])
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    51
        if text:
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    52
            self.state.nested_parse(self.content, self.content_offset, node)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    53
        return [node]
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    54
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    55
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    56
class Topic(BasePseudoSection):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    57
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    58
    node_class = nodes.topic
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    59
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    60
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    61
class Sidebar(BasePseudoSection):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    62
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    63
    node_class = nodes.sidebar
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    64
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    65
    option_spec = BasePseudoSection.option_spec.copy()
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    66
    option_spec['subtitle'] = directives.unchanged_required
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    67
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    68
    def run(self):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    69
        if isinstance(self.state_machine.node, nodes.sidebar):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    70
            raise self.error('The "%s" directive may not be used within a '
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    71
                             'sidebar element.' % self.name)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    72
        return BasePseudoSection.run(self)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    73
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    74
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    75
class LineBlock(Directive):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    76
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    77
    option_spec = {'class': directives.class_option}
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    78
    has_content = True
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    79
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    80
    def run(self):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    81
        self.assert_has_content()
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    82
        block = nodes.line_block(classes=self.options.get('class', []))
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    83
        node_list = [block]
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    84
        for line_text in self.content:
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    85
            text_nodes, messages = self.state.inline_text(
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    86
                line_text.strip(), self.lineno + self.content_offset)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    87
            line = nodes.line(line_text, '', *text_nodes)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    88
            if line_text.strip():
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    89
                line.indent = len(line_text) - len(line_text.lstrip())
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    90
            block += line
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    91
            node_list.extend(messages)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    92
            self.content_offset += 1
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    93
        self.state.nest_line_block_lines(block)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    94
        return node_list
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    95
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    96
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    97
class ParsedLiteral(Directive):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    98
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
    99
    option_spec = {'class': directives.class_option}
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   100
    has_content = True
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   101
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   102
    def run(self):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   103
        set_classes(self.options)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   104
        self.assert_has_content()
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   105
        text = '\n'.join(self.content)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   106
        text_nodes, messages = self.state.inline_text(text, self.lineno)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   107
        node = nodes.literal_block(text, '', *text_nodes, **self.options)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   108
        node.line = self.content_offset + 1
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   109
        return [node] + messages
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   110
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   111
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   112
class Rubric(Directive):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   113
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   114
    required_arguments = 1
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   115
    optional_arguments = 0
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   116
    final_argument_whitespace = True
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   117
    option_spec = {'class': directives.class_option}
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   118
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   119
    def run(self):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   120
        set_classes(self.options)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   121
        rubric_text = self.arguments[0]
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   122
        textnodes, messages = self.state.inline_text(rubric_text, self.lineno)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   123
        rubric = nodes.rubric(rubric_text, '', *textnodes, **self.options)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   124
        return [rubric] + messages
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   125
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   126
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   127
class BlockQuote(Directive):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   128
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   129
    has_content = True
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   130
    classes = []
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   131
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   132
    def run(self):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   133
        self.assert_has_content()
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   134
        elements = self.state.block_quote(self.content, self.content_offset)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   135
        for element in elements:
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   136
            if isinstance(element, nodes.block_quote):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   137
                element['classes'] += self.classes
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   138
        return elements
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   139
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   140
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   141
class Epigraph(BlockQuote):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   142
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   143
    classes = ['epigraph']
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   144
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   145
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   146
class Highlights(BlockQuote):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   147
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   148
    classes = ['highlights']
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   149
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   150
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   151
class PullQuote(BlockQuote):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   152
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   153
    classes = ['pull-quote']
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   154
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   155
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   156
class Compound(Directive):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   157
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   158
    option_spec = {'class': directives.class_option}
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   159
    has_content = True
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   160
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   161
    def run(self):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   162
        self.assert_has_content()
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   163
        text = '\n'.join(self.content)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   164
        node = nodes.compound(text)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   165
        node['classes'] += self.options.get('class', [])
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   166
        self.state.nested_parse(self.content, self.content_offset, node)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   167
        return [node]
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   168
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   169
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   170
class Container(Directive):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   171
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   172
    required_arguments = 0
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   173
    optional_arguments = 1
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   174
    final_argument_whitespace = True
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   175
    has_content = True
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   176
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   177
    def run(self):
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   178
        self.assert_has_content()
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   179
        text = '\n'.join(self.content)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   180
        try:
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   181
            if self.arguments:
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   182
                classes = directives.class_option(self.arguments[0])
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   183
            else:
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   184
                classes = []
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   185
        except ValueError:
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   186
            raise self.error(
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   187
                'Invalid class attribute value for "%s" directive: "%s".'
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   188
                % (self.name, self.arguments[0]))
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   189
        node = nodes.container(text)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   190
        node['classes'].extend(classes)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   191
        self.state.nested_parse(self.content, self.content_offset, node)
d8ac696cc51f helium_7.0-r14027
wbernard
parents:
diff changeset
   192
        return [node]