{
  "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",
  "similar_bug_items": [
    {
      "pr_number": 6592,
      "pr_title": "Fix #6589: autodoc: Formatting issues with autodoc_typehints='none'",
      "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- refs: #6589 ",
      "issue_id": 6589,
      "issue_title": "Formatting issues with autodoc_typehints='none'",
      "issue_body": "**Describe the bug**\r\n\r\nWhen using `autodoc_typehints='none'`, I see two issues currently:\r\n\r\n1. When an annotated parameter has a default value, spaces are inserted around `=` where they are not for unannotated parameters. Consider:\r\n\r\n   ```python\r\n   def foo(x=True, y: bool = True, z = True):\r\n       return x and y and z\r\n   ```\r\n\r\n   The result looks like:\r\n\r\n   **foo**(*x=True, y = True, z=True*)\r\n\r\n2. Return types are not removed. Consider:\r\n\r\n   ```python\r\n   def bar(x: int) -> int:\r\n       return x * 2\r\n   ```\r\n\r\n   The result looks like:\r\n\r\n   **bar**(*x*) -> int\r\n\r\n**To Reproduce**\r\nSteps to reproduce the behavior:\r\n\r\nUse the above examples with the `autodoc_typehints='none'` option, or with the attached project (see below).\r\n\r\n**Expected behavior**\r\n\r\nI expect the annotated and unannotated parameters to be rendered similarly and for return type annotations to be removed as well, as if they were not there originally.\r\n\r\n**Your project**\r\n\r\nSee attached [foobar.zip](https://github.com/sphinx-doc/sphinx/files/3406054/foobar.zip)\r\n\r\n**Environment info**\r\n- OS: [Pop!_OS 18.10]\r\n- Python version: 3.6.8\r\n- Sphinx version: 2.1.2\r\n- Sphinx extensions:  [sphinx.ext.autodoc]\r\n\r\n**Additional context**\r\n\r\n- #6361 \r\n- #5868 \r\n- https://github.com/agronholm/sphinx-autodoc-typehints/pull/78\r\n\r\n",
      "issue_closed_at": "2019-08-02T13:37:16Z",
      "base_commit": "4732ec5edf9e53e2fa78cd5e1ff6bee92f1b27b7",
      "changes": [
        {
          "file": "sphinx/util/inspect.py",
          "type": "function",
          "name": "format_args",
          "class_name": "Signature",
          "code": "def format_args(self, show_annotation: bool = True) -> str:\n        args = []\n        last_kind = None\n        for i, param in enumerate(self.parameters.values()):\n            # skip first argument if subject is bound method\n            if self.skip_first_argument and i == 0:\n                continue\n\n            arg = StringIO()\n\n            # insert '*' between POSITIONAL args and KEYWORD_ONLY args::\n            #     func(a, b, *, c, d):\n            if param.kind == param.KEYWORD_ONLY and last_kind in (param.POSITIONAL_OR_KEYWORD,\n                                                                  param.POSITIONAL_ONLY,\n                                                                  None):\n                args.append('*')\n\n            if param.kind in (param.POSITIONAL_ONLY,\n                              param.POSITIONAL_OR_KEYWORD,\n                              param.KEYWORD_ONLY):\n                arg.write(param.name)\n                if show_annotation and param.annotation is not param.empty:\n                    if isinstance(param.annotation, str) and param.name in self.annotations:\n                        arg.write(': ')\n                        arg.write(self.format_annotation(self.annotations[param.name]))\n                    else:\n                        arg.write(': ')\n                        arg.write(self.format_annotation(param.annotation))\n                if param.default is not param.empty:\n                    if param.annotation is param.empty:\n                        arg.write('=')\n                        arg.write(object_description(param.default))\n                    else:\n                        arg.write(' = ')\n                        arg.write(object_description(param.default))\n            elif param.kind == param.VAR_POSITIONAL:\n                arg.write('*')\n                arg.write(param.name)\n            elif param.kind == param.VAR_KEYWORD:\n                arg.write('**')\n                arg.write(param.name)\n\n            args.append(arg.getvalue())\n            last_kind = param.kind\n\n        if self.return_annotation is inspect.Parameter.empty:\n            return '(%s)' % ', '.join(args)\n        else:\n            if 'return' in self.annotations:\n                annotation = self.format_annotation(self.annotations['return'])\n            else:\n                annotation = self.format_annotation(self.return_annotation)\n\n            return '(%s) -> %s' % (', '.join(args), annotation)"
        },
        {
          "file": "sphinx/util/inspect.py",
          "type": "function",
          "name": "format_args",
          "class_name": "Signature",
          "code": "def format_args(self, show_annotation: bool = True) -> str:\n        args = []\n        last_kind = None\n        for i, param in enumerate(self.parameters.values()):\n            # skip first argument if subject is bound method\n            if self.skip_first_argument and i == 0:\n                continue\n\n            arg = StringIO()\n\n            # insert '*' between POSITIONAL args and KEYWORD_ONLY args::\n            #     func(a, b, *, c, d):\n            if param.kind == param.KEYWORD_ONLY and last_kind in (param.POSITIONAL_OR_KEYWORD,\n                                                                  param.POSITIONAL_ONLY,\n                                                                  None):\n                args.append('*')\n\n            if param.kind in (param.POSITIONAL_ONLY,\n                              param.POSITIONAL_OR_KEYWORD,\n                              param.KEYWORD_ONLY):\n                arg.write(param.name)\n                if show_annotation and param.annotation is not param.empty:\n                    if isinstance(param.annotation, str) and param.name in self.annotations:\n                        arg.write(': ')\n                        arg.write(self.format_annotation(self.annotations[param.name]))\n                    else:\n                        arg.write(': ')\n                        arg.write(self.format_annotation(param.annotation))\n                if param.default is not param.empty:\n                    if param.annotation is param.empty:\n                        arg.write('=')\n                        arg.write(object_description(param.default))\n                    else:\n                        arg.write(' = ')\n                        arg.write(object_description(param.default))\n            elif param.kind == param.VAR_POSITIONAL:\n                arg.write('*')\n                arg.write(param.name)\n            elif param.kind == param.VAR_KEYWORD:\n                arg.write('**')\n                arg.write(param.name)\n\n            args.append(arg.getvalue())\n            last_kind = param.kind\n\n        if self.return_annotation is inspect.Parameter.empty:\n            return '(%s)' % ', '.join(args)\n        else:\n            if 'return' in self.annotations:\n                annotation = self.format_annotation(self.annotations['return'])\n            else:\n                annotation = self.format_annotation(self.return_annotation)\n\n            return '(%s) -> %s' % (', '.join(args), annotation)"
        }
      ]
    },
    {
      "pr_number": 6869,
      "pr_title": "Fix #6867: text: extra spaces are inserted to hyphenated words on folding lines",
      "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- refs: #6867 \r\n- Not to call needless `do_format()` twice, I changed the rule for admonition. After this change, it starts after a blank line.\r\n\r\nBefore:\r\n```\r\nSee also: blah blah blah ...\r\n  blah blah blah ...\r\n```\r\nAfter:\r\n```\r\nSee also:\r\n\r\n  blah blah blah ...\r\n  blah blah blah ...\r\n```",
      "issue_id": 6867,
      "issue_title": "Text writer breaks on hyphens",
      "issue_body": "The text writer uses a custom `TextWrapper` class that breaks hyphenated words. The [parent class][1] from Python standard library has a [`break_on_hyphens`][2] option that allows to disable that, however Sphinx\u2019 `TextWrapper` has a custom `wordsep_re` regular expression so it is not easy to override that:\r\nhttps://github.com/sphinx-doc/sphinx/blob/8c7faed6fcbc6b7d40f497698cb80fc10aee1ab3/sphinx/writers/text.py#L259-L263\r\n\r\nThis leads to two issues.\r\n\r\n1. Some technical terms, program names, email addresses, etc., are being cut at their hypen at the end of line. This makes copy&paste more difficult, and it reads confusingly.\r\n\r\n2. The second issue is related to footnotes. When processing a footnote reference, the `add_text` method is called with `first` argument being `'[N]'`, where N is the footnote number.\r\n\r\n   When `first` is not None, the text is wrapped:\r\n   https://github.com/sphinx-doc/sphinx/blob/8c7faed6fcbc6b7d40f497698cb80fc10aee1ab3/sphinx/writers/text.py#L451\r\n\r\n   then joined by space and wrapped again:\r\n   https://github.com/sphinx-doc/sphinx/blob/8c7faed6fcbc6b7d40f497698cb80fc10aee1ab3/sphinx/writers/text.py#L456-L457\r\n\r\n   Because of this, the words that had a hyphen get an extra space after the hyphen.\r\n\r\n[1]: https://docs.python.org/3/library/textwrap.html#textwrap.TextWrapper\r\n[2]: https://docs.python.org/3/library/textwrap.html#textwrap.TextWrapper.break_on_hyphens\r\n\r\n**To Reproduce**\r\nSteps to reproduce the behavior:\r\n```bash\r\n$ cat >index.rst <<EOF\r\nPlease see the footnote. [#]_\r\n\r\n.. [#]\r\n   Another common way to do this is for ``build`` to depend on\r\n   ``build-stamp`` and to do nothing else, and for the ``build-stamp``\r\n   target to do the building and to ``touch build-stamp`` on completion.\r\nEOF\r\n$ touch conf.py\r\n$ sphinx-build -b text . _build/text\r\n```\r\n\r\nThe result is:\r\n```\r\n$ cat _build/text/index.txt \r\nPlease see the footnote. [1]\r\n\r\n[1] Another common way to do this is for \"build\" to depend on\r\n    \"build- stamp\" and to do nothing else, and for the \"build-stamp\"\r\n    target to do the building and to \"touch build-stamp\" on\r\n    completion.\r\n```\r\n\r\n**Expected behavior**\r\nIn the second line of footnote there should be no space between `build-` and `stamp`.\r\n\r\nI see two possible solutions to achieve that:\r\n- Do not break words on hyphens, or make that configurable.\r\n- Refactor the `end_state` method to avoid calling `do_format()` twice.\r\n\r\n**Environment info**\r\n- OS: Debian GNU/Linux sid\r\n- Python version: 3.7.5\r\n- Sphinx version: latest master\r\n\r\nThis issue is based on two bugs in Debian: [#944330] and [#944331].\r\n\r\n[#944330]: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=944330\r\n[#944331]: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=944331",
      "issue_closed_at": "2020-02-09T06:20:47Z",
      "base_commit": "cf37af27cfef1b620d7d3cd981184ddaedc4922a",
      "changes": [
        {
          "file": "sphinx/writers/text.py",
          "type": "function",
          "name": "do_format",
          "class_name": "TextTranslator",
          "code": "def do_format() -> None:\n            if not toformat:\n                return\n            if wrap:\n                res = my_wrap(''.join(toformat), width=MAXWIDTH - maxindent)\n            else:\n                res = ''.join(toformat).splitlines()\n            if end:\n                res += end\n            result.append((indent, res))"
        },
        {
          "file": "sphinx/writers/text.py",
          "type": "function",
          "name": "depart_admonition",
          "class_name": "TextTranslator",
          "code": "def depart_admonition(self, node: Element) -> None:\n            self.end_state(first=admonitionlabels[name] + ': ')"
        }
      ]
    },
    {
      "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"
        }
      ]
    },
    {
      "pr_number": 6908,
      "pr_title": "Fix #6900: sphinx-build: Allow to pass boolean value via ``-D`` option",
      "pr_body": "### Feature or Bugfix\r\n- Feature\r\n\r\n### Purpose\r\n- refs: #6900 ",
      "issue_id": 6900,
      "issue_title": "Not possible to set  boolean `latex_use_xindy` via `-D` option to sphinx-build",
      "issue_body": "**Describe the bug**\r\n\r\nImpossible to override [`latex_use_xindy`](http://www.sphinx-doc.org/en/master/usage/configuration.html#confval-latex_use_xindy) from command line invocation of `sphinx-build`.\r\n\r\n**To Reproduce**\r\nWith any project\r\n\r\n```\r\nsphinx-build -b latex . _build/latex -D latex_use_xindy=0\r\n```\r\n\r\nproduces\r\n\r\n```\r\nWARNING: The config value `latex_use_xindy' has type `str', defaults to `bool'.\r\n```\r\nAnd the latex output directory will actually be configured for PDF build to use `xindy`.\r\n\r\nNotice that for example\r\n```\r\nsphinx-build -b latex . _build/latex -D latex_use_latex_multicolumn=0\r\n```\r\nraises no warning and behaves as expected. Same for\r\n```\r\nsphinx-build -b latex . _build/latex -D smartquotes=0\r\n```\r\nwhich works fine.\r\n\r\n**Expected behavior**\r\nPeople reading documentation are rewarded with Sphinx behaving as promised :smile:\r\n\r\n**Your project**\r\n\r\nAny project.\r\n\r\n\r\n**Environment info**\r\n- OS: Mac\r\n- Python version: 3.7.5\r\n- Sphinx version: tested with 2.0.1 and current 2.0 branch\r\n\r\n\r\n**Additional context**\r\n\r\n\r\n- #6898 \r\n\r\n",
      "issue_closed_at": "2019-12-15T13:22:09Z",
      "base_commit": "2ec6ce85ef781795dcfb63ccef736b33c6ac96a2",
      "changes": [
        {
          "file": "sphinx/builders/latex/__init__.py",
          "type": "function",
          "name": "setup",
          "class_name": null,
          "code": "def setup(app: Sphinx) -> Dict[str, Any]:\n    app.setup_extension('sphinx.builders.latex.transforms')\n\n    app.add_builder(LaTeXBuilder)\n    app.connect('config-inited', validate_config_values)\n\n    app.add_config_value('latex_engine', default_latex_engine, None,\n                         ENUM('pdflatex', 'xelatex', 'lualatex', 'platex', 'uplatex'))\n    app.add_config_value('latex_documents', default_latex_documents, None)\n    app.add_config_value('latex_logo', None, None, [str])\n    app.add_config_value('latex_appendices', [], None)\n    app.add_config_value('latex_use_latex_multicolumn', False, None)\n    app.add_config_value('latex_use_xindy', default_latex_use_xindy, None)\n    app.add_config_value('latex_toplevel_sectioning', None, None,\n                         ENUM(None, 'part', 'chapter', 'section'))\n    app.add_config_value('latex_domain_indices', True, None, [list])\n    app.add_config_value('latex_show_urls', 'no', None)\n    app.add_config_value('latex_show_pagerefs', False, None)\n    app.add_config_value('latex_elements', {}, None)\n    app.add_config_value('latex_additional_files', [], None)\n\n    app.add_config_value('latex_docclass', default_latex_docclass, None)\n\n    return {\n        'version': 'builtin',\n        'parallel_read_safe': True,\n        'parallel_write_safe': True,\n    }"
        },
        {
          "file": "sphinx/config.py",
          "type": "function",
          "name": "convert_overrides",
          "class_name": "Config",
          "code": "def convert_overrides(self, name, value):\n        # type: (str, Any) -> Any\n        if not isinstance(value, str):\n            return value\n        else:\n            defvalue = self.values[name][0]\n            if self.values[name][2] == Any:\n                return value\n            elif isinstance(defvalue, dict):\n                raise ValueError(__('cannot override dictionary config setting %r, '\n                                    'ignoring (use %r to set individual elements)') %\n                                 (name, name + '.key=value'))\n            elif isinstance(defvalue, list):\n                return value.split(',')\n            elif isinstance(defvalue, int):\n                try:\n                    return int(value)\n                except ValueError:\n                    raise ValueError(__('invalid number %r for config value %r, ignoring') %\n                                     (value, name))\n            elif hasattr(defvalue, '__call__'):\n                return value\n            elif defvalue is not None and not isinstance(defvalue, str):\n                raise ValueError(__('cannot override config setting %r with unsupported '\n                                    'type, ignoring') % name)\n            else:\n                return value"
        }
      ]
    },
    {
      "pr_number": 8658,
      "pr_title": "Close #8573: napoleon: Add more custom section styles",
      "pr_body": "Subject: add more custom section styles\r\n<!--\r\n  Before posting a pull request, please choose a appropriate branch:\r\n\r\n  - Breaking changes: master\r\n  - Critical or severe bugs: X.Y.Z\r\n  - Others: X.Y\r\n\r\n  For more details, see https://www.sphinx-doc.org/en/master/internals/release-process.html#branch-model\r\n-->\r\n\r\n### Feature or Bugfix\r\n<!-- please choose -->\r\n- Feature\r\n\r\n### Purpose\r\n[`napoleon_custom_sections`](https://sphinxcontrib-napoleon.readthedocs.io/en/latest/sphinxcontrib.napoleon.html#sphinxcontrib.napoleon.Config.napoleon_custom_sections) option does not allow to configure the style, and the default style is inconsistent with the rest of the doc. It will be nice if we can choose between a few more styles. This new feature add two more styles that can make the custom section more consistent with the Parameter section or the Return section.\r\nBehavior:\r\n`napoleon_custom_sections = [('Custom Section', 'params_style')]`\r\nor\r\n`napoleon_custom_sections = [('Custom Section', 'returns_style')]`\r\n\r\n\r\n\r\n### Detail\r\n- The default style is inconsistent\r\n![default](https://user-images.githubusercontent.com/24267981/103700248-36409400-4f72-11eb-8f09-dfbcd50a0ac3.png)\r\n\r\n- Display like the parameter section\r\n![para](https://user-images.githubusercontent.com/24267981/103700247-36409400-4f72-11eb-90df-2081f9089ebd.png)\r\n\r\n- Display like the return section\r\n![return](https://user-images.githubusercontent.com/24267981/103700245-35a7fd80-4f72-11eb-8494-843c0a66bc53.png)\r\n\r\n\r\n### Relates\r\n- Others people have expressed a similar desire (see sphinx-contrib/napoleon#2)\r\n- refs: #8573",
      "issue_id": 8573,
      "issue_title": "Napoleon: more custom docstring section styles",
      "issue_body": "Although the `napoleon_custom_sections` option help renders custom docstring section, the style is inconsistent with the rest of the doc.\r\n\r\nFor example, I have a custom docstring section `Side Effect`. I would like it to be displayed as `returns` or `parameters` docstring section. However, `napoleon_custom_sections` option rendesr `Side Effect` in a different style shown in the following picture.\r\n\r\n![\u5fae\u4fe1\u622a\u56fe_20201221155650](https://user-images.githubusercontent.com/24267981/102821833-c9d86900-43a5-11eb-9102-777c7ff3e478.png)\r\n\r\n\r\nIt will be really helpful if we can customize the custom sections a bit more. The following setting has a similar effect, but it renders the Parameters name instead of the custom name.\r\n```\r\nnapoleon_use_param = False\r\nnapoleon_custom_sections = [('Custom name', 'Parameters')]\r\n```\r\nI would like to do something like the following so that my Custom section has the same style as the Parameter section, and it still keeps my custom name:\r\n\r\n```\r\n\r\nnapoleon_custom_sections = [(\"Side Effects\", \"display_like_parameters\"), ...]\r\n\r\n```\r\n\r\nor\r\n\r\n```\r\nnapoleon_custom_sections = [(\"Side Effects\", \"Parameters\") ]\r\nnapoleon_custom_section_rename = False # True is default for backwards compatibility.\r\n```\r\nThe following link includes more details about the solutions:\r\n[Format custom \"Side Effects\" docstring section in-toto/in-toto#401](https://github.com/in-toto/in-toto/issues/401)\r\n\r\nOthers people have expressed a similar desire (see sphinx-contrib/napoleon#2)\r\n\r\nIf you are interested, I would like to provide a PR for this. Thanks!\r\n\r\n\r\n",
      "issue_closed_at": "2021-01-19T12:13:22Z",
      "base_commit": "40f2c832ff3ce2d908b0d8bace3e1f6698eed712",
      "changes": [
        {
          "file": "sphinx/ext/napoleon/docstring.py",
          "type": "function",
          "name": "_load_custom_sections",
          "class_name": "GoogleDocstring",
          "code": "def _load_custom_sections(self) -> None:\n        if self._config.napoleon_custom_sections is not None:\n            for entry in self._config.napoleon_custom_sections:\n                if isinstance(entry, str):\n                    # if entry is just a label, add to sections list,\n                    # using generic section logic.\n                    self._sections[entry.lower()] = self._parse_custom_generic_section\n                else:\n                    # otherwise, assume entry is container;\n                    # [0] is new section, [1] is the section to alias.\n                    # in the case of key mismatch, just handle as generic section.\n                    self._sections[entry[0].lower()] = \\\n                        self._sections.get(entry[1].lower(),\n                                           self._parse_custom_generic_section)"
        },
        {
          "file": "sphinx/ext/napoleon/docstring.py",
          "type": "function",
          "name": "_parse_custom_generic_section",
          "class_name": "GoogleDocstring",
          "code": "def _parse_custom_generic_section(self, section: str) -> List[str]:\n        # for now, no admonition for simple custom sections\n        return self._parse_generic_section(section, False)"
        }
      ]
    }
  ]
}