Merge pull request #7390 from tk0miya/6477_broken_disabling_xref

Fix #6477: Escape first "!" in a cross reference linking no longer possible
This commit is contained in:
Takeshi KOMIYA 2020-03-29 19:14:08 +09:00 committed by GitHub
commit 7887615374
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 17 additions and 3 deletions

View File

@ -23,6 +23,7 @@ Bugs fixed
* #7368: C++, comma operator in expressions, pack expansion in template
argument lists, and more comprehensive error messages in some cases.
* C, C++, fix crash and wrong duplicate warnings related to anon symbols.
* #6477: Escape first "!" in a cross reference linking no longer possible
Testing
--------

View File

@ -126,8 +126,7 @@ class XRefRole(ReferenceRole):
self.refdomain, self.reftype = self.name.split(':', 1)
self.classes = ['xref', self.refdomain, '%s-%s' % (self.refdomain, self.reftype)]
if self.text.startswith('!'):
# if the first character is a bang, don't cross-reference at all
if self.disabled:
return self.create_non_xref_node()
else:
return self.create_xref_node()

View File

@ -409,6 +409,7 @@ class ReferenceRole(SphinxRole):
``self.title`` and ``self.target``.
"""
has_explicit_title = None #: A boolean indicates the role has explicit title or not.
disabled = False #: A boolean indicates the reference is disabled.
title = None #: The link title for the interpreted text.
target = None #: The link target for the interpreted text.
@ -418,6 +419,9 @@ class ReferenceRole(SphinxRole):
def __call__(self, name: str, rawtext: str, text: str, lineno: int,
inliner: Inliner, options: Dict = {}, content: List[str] = []
) -> Tuple[List[Node], List[system_message]]:
# if the first character is a bang, don't cross-reference at all
self.disabled = text.startswith('!')
matched = self.explicit_title_re.match(text)
if matched:
self.has_explicit_title = True

View File

@ -19,7 +19,8 @@ from html5lib import HTMLParser
from sphinx import addnodes
from sphinx.addnodes import (
desc, desc_addname, desc_content, desc_name, desc_signature, glossary, index
desc, desc_addname, desc_content, desc_name, desc_signature, glossary, index,
pending_xref
)
from sphinx.domains.std import StandardDomain
from sphinx.testing import restructuredtext
@ -373,3 +374,12 @@ def test_productionlist(app, status, warning):
text = (app.outdir / 'LineContinuation.html').read_text()
assert "A</strong> ::= B C D E F G" in text
def test_disabled_docref(app):
text = (":doc:`index`\n"
":doc:`!index`\n")
doctree = restructuredtext.parse(app, text)
assert_node(doctree, ([nodes.paragraph, ([pending_xref, nodes.inline, "index"],
"\n",
[nodes.inline, "index"])],))