{
    "Selected_candidate": {
        "pr_number": 6237,
        "pr_title": "Fix #6220, #6225: napoleon: AttributeError is raised for raised section having references",
        "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- refs: #6220, #6225\r\n",
        "issue_id": 6220,
        "issue_title": "Sphinx 2.0: napoleon extension fails to parse exception with tilde",
        "issue_body": "**Describe the bug**\r\nUsing the napoleon extension with `napoleon_numpy_docstring = False`, an exception with a tilde in front fails to parse.\r\n\r\nI have a docstring\r\n\r\n```python\r\n\"\"\"\r\n    Raises:\r\n        ValueError: description.\r\n        ~mymodule.MyError: description.\r\n\"\"\"\r\n```\r\n\r\nThis regex fails:\r\n\r\nhttps://github.com/sphinx-doc/sphinx/blob/1499a97c28820ca2ff525d675e9c86fee917532d/sphinx/ext/napoleon/docstring.py#L103-L104\r\n\r\nat this line:\r\n\r\nhttps://github.com/sphinx-doc/sphinx/blob/1499a97c28820ca2ff525d675e9c86fee917532d/sphinx/ext/napoleon/docstring.py#L703\r\n\r\n**To Reproduce**\r\n\r\n```python\r\nfrom sphinx.ext.napoleon.docstring import GoogleDocstring\r\nassert GoogleDocstring._name_rgx.match('~mymodule.MyError') is None\r\n```\r\n\r\n**Expected behavior**\r\nSphinx renders it as if I used `:raises ~mymodule.MyError: description.`\r\n\r\n**Environment info**\r\n- Sphinx version: 2.0.0\r\n- Sphinx extensions:  sphinx.ext.napoleon\r\n\r\n**Additional context**\r\nBug introduced by #4046\r\n\r\n",
        "issue_closed_at": "2019-04-04T14:48:05Z",
        "base_commit": "cbefc01b7384bcd1b99eb72d22b6317164e0b6dd",
        "changes": [
            {
                "file": "sphinx/ext/napoleon/docstring.py",
                "type": "function",
                "name": "_parse_raises_section",
                "class_name": "GoogleDocstring",
                "code": "def _parse_raises_section(self, section):\n        # type: (str) -> List[str]\n        fields = self._consume_fields(parse_type=False, prefer_type=True)\n        lines = []  # type: List[str]\n        for _name, _type, _desc in fields:\n            m = self._name_rgx.match(_type).groupdict()\n            if m['role']:\n                _type = m['name']\n            _type = ' ' + _type if _type else ''\n            _desc = self._strip_empty(_desc)\n            _descs = ' ' + '\\n    '.join(_desc) if any(_desc) else ''\n            lines.append(':raises%s:%s' % (_type, _descs))\n        if lines:\n            lines.append('')\n        return lines"
            }
        ]
    },
    "Justification": "Candidate C is the most relevant because it directly pertains to the functionality of the `napoleon` extension, which is the same component involved in the CURRENT bug report. It addresses a parsing issue within the exception section of docstrings, indicating similar structural handling of docstring formatting that could lead to misrendering. The reported bug's core concern about formatting rules aligns well with the CURRENT bug's issue of inconsistency in rendering sections based on the config options. Additionally, both bugs relate to custom formats in docstrings, making the insights from Candidate C extremely useful in debugging the CURRENT bug."
}