Commit 737d241a authored by Georg Brandl's avatar Georg Brandl

fix deprecated-removed directive with sphinx 1.2

parent 6952a1cd
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
Sphinx extension with Python doc-specific markup. Sphinx extension with Python doc-specific markup.
:copyright: 2008-2013 by Georg Brandl. :copyright: 2008-2014 by Georg Brandl.
:license: Python license. :license: Python license.
""" """
...@@ -145,8 +145,6 @@ class PyDecoratorMethod(PyDecoratorMixin, PyClassmember): ...@@ -145,8 +145,6 @@ class PyDecoratorMethod(PyDecoratorMixin, PyClassmember):
from sphinx.locale import versionlabels from sphinx.locale import versionlabels
from sphinx.util.compat import Directive from sphinx.util.compat import Directive
versionlabels['deprecated-removed'] = \
'Deprecated since version %s, will be removed in version %s'
class DeprecatedRemoved(Directive): class DeprecatedRemoved(Directive):
has_content = True has_content = True
...@@ -155,24 +153,40 @@ class DeprecatedRemoved(Directive): ...@@ -155,24 +153,40 @@ class DeprecatedRemoved(Directive):
final_argument_whitespace = True final_argument_whitespace = True
option_spec = {} option_spec = {}
_label = 'Deprecated since version %s, will be removed in version %s'
def run(self): def run(self):
node = addnodes.versionmodified() node = addnodes.versionmodified()
node.document = self.state.document node.document = self.state.document
node['type'] = 'deprecated-removed' node['type'] = 'deprecated-removed'
version = (self.arguments[0], self.arguments[1]) version = (self.arguments[0], self.arguments[1])
node['version'] = version node['version'] = version
text = self._label % version
if len(self.arguments) == 3: if len(self.arguments) == 3:
inodes, messages = self.state.inline_text(self.arguments[2], inodes, messages = self.state.inline_text(self.arguments[2],
self.lineno+1) self.lineno+1)
node.extend(inodes) para = nodes.paragraph(self.arguments[2], '', *inodes)
if self.content: node.append(para)
self.state.nested_parse(self.content, self.content_offset, node) else:
ret = [node] + messages messages = []
if self.content:
self.state.nested_parse(self.content, self.content_offset, node)
if len(node):
if isinstance(node[0], nodes.paragraph) and node[0].rawsource:
content = nodes.inline(node[0].rawsource, translatable=True)
content.source = node[0].source
content.line = node[0].line
content += node[0].children
node[0].replace_self(nodes.paragraph('', '', content))
node[0].insert(0, nodes.inline('', '%s: ' % text,
classes=['versionmodified']))
else: else:
ret = [node] para = nodes.paragraph('', '',
nodes.inline('', '%s.' % text, classes=['versionmodified']))
node.append(para)
env = self.state.document.settings.env env = self.state.document.settings.env
env.note_versionchange('deprecated', version[0], node, self.lineno) env.note_versionchange('deprecated', version[0], node, self.lineno)
return ret return [node] + messages
# Support for including Misc/NEWS # Support for including Misc/NEWS
......
...@@ -342,7 +342,7 @@ dl.glossary dt { ...@@ -342,7 +342,7 @@ dl.glossary dt {
padding: 7px; padding: 7px;
} }
div.deprecated p { div.deprecated p, div.deprecated-removed p {
margin-bottom: 0; margin-bottom: 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment