{
  "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.",
  "instance_id": "sphinx-doc__sphinx-8713",
  "repo": "sphinx-doc/sphinx",
  "created_at": "2021-01-20T14:24:12Z",
  "problem_statement": "napoleon_use_param should also affect \"other parameters\" section\nSubject: napoleon_use_param should also affect \"other parameters\" section\r\n\r\n### Problem\r\nCurrently, napoleon always renders the Other parameters section as if napoleon_use_param was False, see source\r\n```\r\n    def _parse_other_parameters_section(self, section):\r\n        # type: (unicode) -> List[unicode]\r\n        return self._format_fields(_('Other Parameters'), self._consume_fields())\r\n\r\n    def _parse_parameters_section(self, section):\r\n        # type: (unicode) -> List[unicode]\r\n        fields = self._consume_fields()\r\n        if self._config.napoleon_use_param:\r\n            return self._format_docutils_params(fields)\r\n        else:\r\n            return self._format_fields(_('Parameters'), fields)\r\n```\r\nwhereas it would make sense that this section should follow the same formatting rules as the Parameters section.\r\n\r\n#### Procedure to reproduce the problem\r\n```\r\nIn [5]: print(str(sphinx.ext.napoleon.NumpyDocstring(\"\"\"\\ \r\n   ...: Parameters \r\n   ...: ---------- \r\n   ...: x : int \r\n   ...:  \r\n   ...: Other parameters \r\n   ...: ---------------- \r\n   ...: y: float \r\n   ...: \"\"\")))                                                                                                                                                                                      \r\n:param x:\r\n:type x: int\r\n\r\n:Other Parameters: **y** (*float*)\r\n```\r\n\r\nNote the difference in rendering.\r\n\r\n#### Error logs / results\r\nSee above.\r\n\r\n#### Expected results\r\n```\r\n:param x:\r\n:type x: int\r\n\r\n:Other Parameters:  // Or some other kind of heading.\r\n:param: y\r\n:type y: float\r\n```\r\n\r\nAlternatively another separate config value could be introduced, but that seems a bit overkill.\r\n\r\n### Reproducible project / your project\r\nN/A\r\n\r\n### Environment info\r\n- OS: Linux\r\n- Python version: 3.7\r\n- Sphinx version: 1.8.1\r\n\n",
  "patch": "diff --git a/sphinx/ext/napoleon/docstring.py b/sphinx/ext/napoleon/docstring.py\n--- a/sphinx/ext/napoleon/docstring.py\n+++ b/sphinx/ext/napoleon/docstring.py\n@@ -682,7 +682,13 @@ def _parse_notes_section(self, section: str) -> List[str]:\n         return self._parse_generic_section(_('Notes'), use_admonition)\n \n     def _parse_other_parameters_section(self, section: str) -> List[str]:\n-        return self._format_fields(_('Other Parameters'), self._consume_fields())\n+        if self._config.napoleon_use_param:\n+            # Allow to declare multiple parameters at once (ex: x, y: int)\n+            fields = self._consume_fields(multiple=True)\n+            return self._format_docutils_params(fields)\n+        else:\n+            fields = self._consume_fields()\n+            return self._format_fields(_('Other Parameters'), fields)\n \n     def _parse_parameters_section(self, section: str) -> List[str]:\n         if self._config.napoleon_use_param:\n"
}