{
  "original_problem": {
    "instance_id": "sphinx-doc__sphinx-10451",
    "repo": "sphinx-doc/sphinx",
    "created_at": "2022-05-15T11:49:39Z",
    "problem_statement": "Fix duplicated *args and **kwargs with autodoc_typehints\nFix duplicated *args and **kwargs with autodoc_typehints\r\n\r\n### Bugfix\r\n- Bugfix\r\n\r\n### Detail\r\nConsider this\r\n```python\r\nclass _ClassWithDocumentedInitAndStarArgs:\r\n    \"\"\"Class docstring.\"\"\"\r\n\r\n    def __init__(self, x: int, *args: int, **kwargs: int) -> None:\r\n        \"\"\"Init docstring.\r\n\r\n        :param x: Some integer\r\n        :param *args: Some integer\r\n        :param **kwargs: Some integer\r\n        \"\"\"\r\n```\r\nwhen using the autodoc extension and the setting `autodoc_typehints = \"description\"`.\r\n\r\nWIth sphinx 4.2.0, the current output is\r\n```\r\nClass docstring.\r\n\r\n   Parameters:\r\n      * **x** (*int*) --\r\n\r\n      * **args** (*int*) --\r\n\r\n      * **kwargs** (*int*) --\r\n\r\n   Return type:\r\n      None\r\n\r\n   __init__(x, *args, **kwargs)\r\n\r\n      Init docstring.\r\n\r\n      Parameters:\r\n         * **x** (*int*) -- Some integer\r\n\r\n         * ***args** --\r\n\r\n           Some integer\r\n\r\n         * ****kwargs** --\r\n\r\n           Some integer\r\n\r\n         * **args** (*int*) --\r\n\r\n         * **kwargs** (*int*) --\r\n\r\n      Return type:\r\n         None\r\n```\r\nwhere the *args and **kwargs are duplicated and incomplete.\r\n\r\nThe expected output is\r\n```\r\n  Class docstring.\r\n\r\n   Parameters:\r\n      * **x** (*int*) --\r\n\r\n      * ***args** (*int*) --\r\n\r\n      * ****kwargs** (*int*) --\r\n\r\n   Return type:\r\n      None\r\n\r\n   __init__(x, *args, **kwargs)\r\n\r\n      Init docstring.\r\n\r\n      Parameters:\r\n         * **x** (*int*) -- Some integer\r\n\r\n         * ***args** (*int*) --\r\n\r\n           Some integer\r\n\r\n         * ****kwargs** (*int*) --\r\n\r\n           Some integer\r\n\r\n      Return type:\r\n         None\r\n\r\n```\n",
    "patch": "diff --git a/sphinx/ext/autodoc/typehints.py b/sphinx/ext/autodoc/typehints.py\n--- a/sphinx/ext/autodoc/typehints.py\n+++ b/sphinx/ext/autodoc/typehints.py\n@@ -115,7 +115,15 @@ def modify_field_list(node: nodes.field_list, annotations: Dict[str, str],\n         if name == 'return':\n             continue\n \n-        arg = arguments.get(name, {})\n+        if '*' + name in arguments:\n+            name = '*' + name\n+            arguments.get(name)\n+        elif '**' + name in arguments:\n+            name = '**' + name\n+            arguments.get(name)\n+        else:\n+            arg = arguments.get(name, {})\n+\n         if not arg.get('type'):\n             field = nodes.field()\n             field += nodes.field_name('', 'type ' + name)\n@@ -167,13 +175,19 @@ def augment_descriptions_with_types(\n             has_type.add('return')\n \n     # Add 'type' for parameters with a description but no declared type.\n-    for name in annotations:\n+    for name, annotation in annotations.items():\n         if name in ('return', 'returns'):\n             continue\n+\n+        if '*' + name in has_description:\n+            name = '*' + name\n+        elif '**' + name in has_description:\n+            name = '**' + name\n+\n         if name in has_description and name not in has_type:\n             field = nodes.field()\n             field += nodes.field_name('', 'type ' + name)\n-            field += nodes.field_body('', nodes.paragraph('', annotations[name]))\n+            field += nodes.field_body('', nodes.paragraph('', annotation))\n             node += field\n \n     # Add 'rtype' if 'return' is present and 'rtype' isn't.\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_6589",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve formatting inconsistencies in Sphinx autodoc related to type hints, suggesting similar root causes and fix strategies."
      },
      {
        "idx": 2,
        "id": "similar_9932",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about empty sections in docstrings, which is unrelated to the duplication and formatting problem in the current issue."
      },
      {
        "idx": 3,
        "id": "similar_1922",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about character case handling in a search engine, which is unrelated to documentation formatting or type hint handling."
      },
      {
        "idx": 4,
        "id": "similar_8942",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves parsing C++ syntax, which is unrelated to Python type hint duplication in documentation."
      },
      {
        "idx": 5,
        "id": "similar_8372",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about performance regression, which does not relate to the specific formatting and duplication problem in the current issue."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "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_id": 6589,
        "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_closed_at": "2019-08-02T13:37:16Z",
        "base_commit": "4732ec5edf9e53e2fa78cd5e1ff6bee92f1b27b7"
      },
      "summary": "### Summary:\n\nThis issue is related to formatting inconsistencies and incomplete type hint removal when using the `autodoc_typehints='none'` option in the Sphinx documentation generator. \n\n1. **Problem Description:**\n   - The primary problem is the inconsistency in how function signatures are formatted when using the `autodoc_typehints='none'` setting. This setting is intended to omit type hints from the generated documentation, but it currently exhibits inconsistent spacing and fails to remove return type annotations completely.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - When a function parameter is annotated and has a default value, spaces are incorrectly added around the equal sign (`=`), whereas unannotated parameters do not have these spaces.\n   - The return type annotations are not removed from the function signatures, appearing in the documentation even though the `autodoc_typehints='none'` option should omit them.\n\n3. **Affected Components or Systems:**\n   - The issue specifically affects the Sphinx documentation generator, particularly the `sphinx.ext.autodoc` extension which handles the generation of documentation from Python code with type hints.\n\n4. **Potential Impact or Severity:**\n   - This issue can lead to confusion and a lack of professional appearance in the generated documentation due to inconsistent formatting. It may also mislead users regarding the presence of type hints when they are not intended to be shown, potentially affecting the readability and usability of the documentation.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   - The formatting inconsistencies arise from how annotated and unannotated parameters are processed differently in terms of spacing around default values.\n   - The failure to remove return type annotations suggests a gap in the implementation of the `autodoc_typehints='none'` functionality, where return types are not being properly filtered out.\n\nThe changes in the `sphinx/util/inspect.py` file, specifically in the `Signature.format_args` function, indicate that the solution likely involved adjusting how function signature arguments are formatted to ensure consistency and correct omission of type hints.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Formatting issues with autodoc_typehints='none'\n\nBody:\n**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\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsphinx/util/inspect.py\n  function: Signature.format_args\n  function: Signature.format_args\n"
    },
    {
      "similar_issue": {
        "issue_title": "Napoleon emits empty \"returns\" sections",
        "issue_body": "### Describe the bug\n\n![image](https://user-images.githubusercontent.com/401438/144486463-e96a1bbb-46c5-42bf-8544-d6864ecea8ac.png)\r\n\r\n```python\r\ndef get_task(task_id):\r\n    \"\"\"\r\n    Get a task object\r\n\r\n    Args:\r\n        task_id: numeric ID of task\r\n\r\n    Returns:\r\n        Task:\r\n    \"\"\"\r\n```\n\n### How to Reproduce\n\nSee above\n\n### Expected behavior\n\nDon't emit the empty section\n\n### Your project\n\n(private)\n\n### Screenshots\n\n_No response_\n\n### OS\n\nMac, Linux/Container\n\n### Python version\n\n3.10\n\n### Sphinx version\n\nlatest\n\n### Sphinx extensions\n\nautodoc, intersphinx, todo, viewcode, napoleon, sphinx_inline_tabs, prettyspecialmethods\n\n### Extra tools\n\n_No response_\n\n### Additional context\n\n_No response_",
        "issue_id": 9932,
        "pr_number": 10101,
        "pr_title": "Fix empty returns section",
        "pr_body": "### Feature or Bugfix\r\n\r\nBugfix\r\n\r\nCloses #9932\r\n\r\n",
        "issue_closed_at": "2022-01-15T17:40:58Z",
        "base_commit": "0938c193ea6f56dbb930bfb323602bc4e2b7b9c6"
      },
      "summary": "### Summary:\nThis issue pertains to a problem within the Sphinx documentation generator, specifically involving the Napoleon extension, which is responsible for parsing NumPy and Google style docstrings. The primary symptom is the generation of empty \"Returns\" sections when documenting Python functions that do not explicitly return a value. This behavior affects the quality of generated documentation by introducing unnecessary and potentially confusing empty sections.\n\n1. **Problem description in general terms**: \n   The Sphinx Napoleon extension is incorrectly emitting empty \"Returns\" sections in the generated documentation. This occurs when parsing docstrings for functions that have a \"Returns\" section defined without a corresponding return value specified.\n\n2. **Key symptoms and behaviors observed**: \n   The main symptom is the presence of empty \"Returns\" sections in the output documentation for functions that do not return a value, as highlighted by a code example showing a typical function docstring format.\n\n3. **Affected components or systems**: \n   The issue affects the Sphinx documentation generator, specifically the Napoleon extension's functionality related to parsing Google-style docstrings. It also indirectly impacts any projects using this tool to generate documentation, as it can degrade the clarity and quality of the output.\n\n4. **Potential impact or severity**: \n   The impact is primarily on documentation quality. While it may not affect the functionality of the software being documented, it can lead to confusion for users and maintainers reading the generated documentation. The severity is moderate, as it affects the professional appearance and usability of the documentation.\n\n5. **Relevant technical details abstracted for broader understanding**: \n   The problem lies in the parsing logic of the Napoleon extension, particularly in the functions responsible for interpreting the \"Returns\" section of Google-style docstrings. The fix involves modifying the parsing functions to avoid emitting empty sections when no return value is specified. The relevant code changes were made in the `sphinx/ext/napoleon/docstring.py` file, specifically within the `GoogleDocstring._parse_references_section` and `GoogleDocstring._parse_returns_section` functions.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Napoleon emits empty \"returns\" sections\n\nBody:\n### Describe the bug\n\n![image](https://user-images.githubusercontent.com/401438/144486463-e96a1bbb-46c5-42bf-8544-d6864ecea8ac.png)\r\n\r\n```python\r\ndef get_task(task_id):\r\n    \"\"\"\r\n    Get a task object\r\n\r\n    Args:\r\n        task_id: numeric ID of task\r\n\r\n    Returns:\r\n        Task:\r\n    \"\"\"\r\n```\n\n### How to Reproduce\n\nSee above\n\n### Expected behavior\n\nDon't emit the empty section\n\n### Your project\n\n(private)\n\n### Screenshots\n\n_No response_\n\n### OS\n\nMac, Linux/Container\n\n### Python version\n\n3.10\n\n### Sphinx version\n\nlatest\n\n### Sphinx extensions\n\nautodoc, intersphinx, todo, viewcode, napoleon, sphinx_inline_tabs, prettyspecialmethods\n\n### Extra tools\n\n_No response_\n\n### Additional context\n\n_No response_\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsphinx/ext/napoleon/docstring.py\n  function: GoogleDocstring._parse_references_section\n  function: GoogleDocstring._parse_returns_section\n"
    },
    {
      "similar_issue": {
        "issue_title": "Upper characters problem in French stemmer",
        "issue_body": "I've found a bug in the HTML / Javascript search engine with the French language. The bug is actually related to the indexing of the doctree. The HTML / Javascript search engine expects only lower characters in the index. When indexing, the English stemmer removes upper characters and replace them with lower ones (with .lower()). However, the French stemmer (in sphinx/search/fr.py) keeps the upper characters. Consequently, any word with an upper character in wrongly indexed in French.\nThis can easily be fixed by adding \".lower()\" in SearchFrench.stem().\n",
        "issue_id": 1922,
        "pr_number": 4396,
        "pr_title": "Fix #1922: Upper characters problem in French HTML Search",
        "pr_body": "refs: #1922 ",
        "issue_closed_at": "2018-01-15T01:15:45Z",
        "base_commit": "79501767d8a3e7433847af924fa4b9ff5d872612"
      },
      "summary": "### Summary:\nThis issue involves a discrepancy in character handling between different language stemmers used by an HTML / Javascript search engine. Specifically, the problem arises within the French language stemmer, where uppercase characters are not converted to lowercase during the indexing process. This inconsistency leads to incorrect indexing of French words with uppercase letters, as the search engine expects all indexed words to be in lowercase. The English stemmer correctly handles this by converting uppercase characters to lowercase, but the French stemmer does not.\n\n1. **Problem Description in General Terms:** The inconsistency in character case handling during the indexing process causes issues with search functionality in different languages, particularly affecting non-English language processing.\n\n2. **Key Symptoms and Behaviors Observed:** Words with uppercase characters in French are incorrectly indexed, leading to potential search mismatches or failures within the search engine.\n\n3. **Affected Components or Systems:** This issue affects the French stemmer module within the Sphinx search infrastructure, specifically the `sphinx/search/fr.py` file.\n\n4. **Potential Impact or Severity:** The impact may include degraded search accuracy for French language content, potentially affecting user experience and the reliability of search functionality in multilingual environments.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:** The solution involves modifying the French stemmer's behavior to align with the English stemmer by converting all characters to lowercase during the stemming process. This is achieved by adding a `.lower()` method call in the `SearchFrench.stem()` function.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Upper characters problem in French stemmer\n\nBody:\nI've found a bug in the HTML / Javascript search engine with the French language. The bug is actually related to the indexing of the doctree. The HTML / Javascript search engine expects only lower characters in the index. When indexing, the English stemmer removes upper characters and replace them with lower ones (with .lower()). However, the French stemmer (in sphinx/search/fr.py) keeps the upper characters. Consequently, any word with an upper character in wrongly indexed in French.\nThis can easily be fixed by adding \".lower()\" in SearchFrench.stem().\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsphinx/search/fr.py\n  function: SearchFrench.init\n"
    },
    {
      "similar_issue": {
        "issue_title": "Support C++20's spaceship operator",
        "issue_body": "C++20 has the new spaceship operator `<=>` for three way comparisons which can also be [defaulted](https://en.cppreference.com/w/cpp/language/default_comparisons) (not sure if the latter matters to Sphinx).\r\n\r\nI hope this is a problem with Sphinx at all and not with the Breathe extension I'm also using.\r\n\r\nFor example, this reST code in Sphinx\r\n```\r\n.. cpp:function:: std::strong_ordering operator<=>(Foo, Foo)\r\n```\r\ncurrently leads to the following warning/error\r\n```\r\nWARNING: Error when parsing function declaration.\r\nIf the function has no return type:\r\n  Error in declarator or parameters-and-qualifiers\r\n  Invalid C++ declaration: Expecting \"(\" in parameters-and-qualifiers. [error at 21]\r\n    std::strong_ordering operator<=>(Foo, Foo)\r\n    ---------------------^\r\nIf the function has a return type:\r\n  Error in declarator or parameters-and-qualifiers\r\n  If pointer to member declarator:\r\n    Invalid C++ declaration: Expected '::' in pointer to member (function). [error at 31]\r\n      std::strong_ordering operator<=>(Foo, Foo)\r\n      -------------------------------^\r\n  If declarator-id:\r\n    Invalid C++ declaration: Expecting \"(\" in parameters-and-qualifiers. [error at 31]\r\n      std::strong_ordering operator<=>(Foo, Foo)\r\n      -------------------------------^\r\n```",
        "issue_id": 8942,
        "pr_number": 8951,
        "pr_title": "C++, support spaceship operator",
        "pr_body": "### Feature or Bugfix\r\n- Feature\r\n\r\n### Purpose\r\nSupport the ``<=>`` operator added in C++20.\r\n\r\n### Details\r\nNote that when written in roles the ``<`` may need to escaped to disambiguate with xrefs with explicit titles. E.g., ``:cpp:func:`operator<=>` `` is an (attempted) reference to ``=`` with title ``operator``, but ``:cpp:func:`operator\\<=>` `` is a reference to ``operator<=>`` with implicit title.\r\n\r\n### Relates\r\nFixes #8942.\r\n\r\n",
        "issue_closed_at": "2021-03-02T19:48:17Z",
        "base_commit": "b923165d5ef289ba39bb964201d4a036eb5a5ff6"
      },
      "summary": "### Summary:\nThis issue pertains to the inability of Sphinx, a documentation generator commonly used for Python and C++, to correctly parse and handle the C++20 spaceship operator (`<=>`) when used in documentation written in reStructuredText (reST). The spaceship operator, introduced in C++20, facilitates three-way comparisons and can be defaulted for certain types, enhancing the language's expressiveness and functionality. The problem becomes evident when Sphinx attempts to process a C++ function declaration using the spaceship operator, resulting in warnings and errors related to parsing the function's declaration. These errors suggest difficulties in recognizing the operator as part of a valid C++ function signature, leading to incorrect assumptions about the syntax, particularly around parameter declarations and return types.\n\nKey symptoms include error messages during the parsing of function declarations, specifically indicating that the parser is unable to correctly interpret the placement of the operator within the function declaration syntax. This results in errors such as expecting a parenthesis in the parameters-and-qualifiers section of the declaration.\n\nThe affected component is primarily the C++ domain parser within Sphinx, which is responsible for interpreting C++ code within documentation. The issue might also relate to the Breathe extension, which interfaces Doxygen-generated XML with Sphinx, although the report does not confirm this.\n\nThe potential impact is significant for developers and documentation writers using Sphinx to generate documentation for C++20 codebases, as it prevents accurate and error-free documentation of functions using the spaceship operator. This could lead to incomplete or incorrect documentation, affecting code understanding and maintenance.\n\nThe patch addresses the issue by modifying the C++ domain parsing logic in Sphinx's codebase, specifically within the `DefinitionParser._parse_logical_or_expression` function and other related lines in `sphinx/domains/cpp.py`. These changes likely involve updating the parser to recognize the `<=>` operator as a valid part of function declarations, ensuring correct handling and interpretation in the documentation process.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Support C++20's spaceship operator\n\nBody:\nC++20 has the new spaceship operator `<=>` for three way comparisons which can also be [defaulted](https://en.cppreference.com/w/cpp/language/default_comparisons) (not sure if the latter matters to Sphinx).\r\n\r\nI hope this is a problem with Sphinx at all and not with the Breathe extension I'm also using.\r\n\r\nFor example, this reST code in Sphinx\r\n```\r\n.. cpp:function:: std::strong_ordering operator<=>(Foo, Foo)\r\n```\r\ncurrently leads to the following warning/error\r\n```\r\nWARNING: Error when parsing function declaration.\r\nIf the function has no return type:\r\n  Error in declarator or parameters-and-qualifiers\r\n  Invalid C++ declaration: Expecting \"(\" in parameters-and-qualifiers. [error at 21]\r\n    std::strong_ordering operator<=>(Foo, Foo)\r\n    ---------------------^\r\nIf the function has a return type:\r\n  Error in declarator or parameters-and-qualifiers\r\n  If pointer to member declarator:\r\n    Invalid C++ declaration: Expected '::' in pointer to member (function). [error at 31]\r\n      std::strong_ordering operator<=>(Foo, Foo)\r\n      -------------------------------^\r\n  If declarator-id:\r\n    Invalid C++ declaration: Expecting \"(\" in parameters-and-qualifiers. [error at 31]\r\n      std::strong_ordering operator<=>(Foo, Foo)\r\n      -------------------------------^\r\n```\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsphinx/domains/cpp.py\n  line: line 306\n  line: line 494\n  line: line 528\n  function: DefinitionParser._parse_logical_or_expression\n"
    },
    {
      "similar_issue": {
        "issue_title": "Sphinx 3.3 is roughly 3.2x slower than sphinx 3.2.1",
        "issue_body": "**Describe the bug**\r\n\r\nWe recently noticed the doc builds for the 🤗 Transformers library were a lot slower with the recent release. We pinned the version to 3.2.1 for now and it solved the issue, but we wanted to let you know about the slowdown.\r\n\r\n**To Reproduce**\r\nSteps to reproduce the behavior:\r\n```\r\n$ git clone https://github.com/huggingface/transformers/\r\n$ cd transformers\r\n$ pip install --upgrade pip\r\n$ pip install .[tf,torch,sentencepiece,docs]\r\n$ cd docs\r\n$ make html SPHINXOPTS=\"-W\"\r\n```\r\nWith sphinx 3.3.0, the build takes 5min21s on a CircleCI Docker Medium (the size doesn't really impact execution time), whereas sphinx 3.2.1 completes the build in 1min40s (on the same machine). Most of the slowdown is coming in the \"[reading sources]\" part of the build.\r\n\r\n**Expected behavior**\r\nI'd expect the change of version to not impact the time of the build in such a way.\r\n\r\n**Your project**\r\nLink to your sphinx project, or attach zipped small project sample.\r\n\r\n**Environment info**\r\n- OS: Linux\r\n- Python version: 3.7.9\r\n- Sphinx version: 3.2.1/3.3.0\r\n- Sphinx extensions:\r\n    - 'sphinx.ext.autodoc',\r\n    - 'sphinx.ext.coverage',\r\n    - 'sphinx.ext.napoleon',\r\n    - 'recommonmark',\r\n    - 'sphinx.ext.viewcode',\r\n    - 'sphinx_markdown_tables',\r\n    - 'sphinx_copybutton'\r\n\r\n\r\n",
        "issue_id": 8372,
        "pr_number": 8387,
        "pr_title": "Fix #8372: autodoc: autoclass directive became slower than Sphinx-3.2",
        "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n* The result of ModuleAnalyzer.parse() is not cached\r\n* autodoc tries to search overloaded constructor methods to the root\r\n  class even if a definition found",
        "issue_closed_at": "2020-11-09T15:31:09Z",
        "base_commit": "1193d83166b7d889343d5aa0268d6c2e9349e692"
      },
      "summary": "### Summary:\nThis issue is related to a significant performance regression observed in a software tool, Sphinx, following an update from version 3.2.1 to 3.3.0. The problem manifests as a marked slowdown in the documentation build process, specifically during the \"reading sources\" phase, which becomes approximately 3.2 times slower. This issue was identified while building the documentation for the 🤗 Transformers library. The slowdown was detected in a continuous integration environment using Docker, indicating that the issue is not tied to specific hardware configurations. \n\nThe affected components include the Sphinx documentation generator, and the slowdown occurs irrespective of the build environment size, suggesting that the new version of Sphinx introduces inefficiencies in processing documentation sources. The severity of this issue is notable as it impacts the efficiency of documentation generation, which is a critical task for maintaining clear and up-to-date project documentation. \n\nTechnical analysis pointed to changes in specific functions within the Sphinx codebase, namely `ClassDocumenter.get_overloaded_signatures` in `sphinx/ext/autodoc/__init__.py`, and `ModuleAnalyzer.__init__` and `ModuleAnalyzer.parse` in `sphinx/pycode/__init__.py`. These functions are likely contributing to the performance regression, highlighting potential areas for optimization or bug fixes to restore the tool's previous performance levels.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Sphinx 3.3 is roughly 3.2x slower than sphinx 3.2.1\n\nBody:\n**Describe the bug**\r\n\r\nWe recently noticed the doc builds for the 🤗 Transformers library were a lot slower with the recent release. We pinned the version to 3.2.1 for now and it solved the issue, but we wanted to let you know about the slowdown.\r\n\r\n**To Reproduce**\r\nSteps to reproduce the behavior:\r\n```\r\n$ git clone https://github.com/huggingface/transformers/\r\n$ cd transformers\r\n$ pip install --upgrade pip\r\n$ pip install .[tf,torch,sentencepiece,docs]\r\n$ cd docs\r\n$ make html SPHINXOPTS=\"-W\"\r\n```\r\nWith sphinx 3.3.0, the build takes 5min21s on a CircleCI Docker Medium (the size doesn't really impact execution time), whereas sphinx 3.2.1 completes the build in 1min40s (on the same machine). Most of the slowdown is coming in the \"[reading sources]\" part of the build.\r\n\r\n**Expected behavior**\r\nI'd expect the change of version to not impact the time of the build in such a way.\r\n\r\n**Your project**\r\nLink to your sphinx project, or attach zipped small project sample.\r\n\r\n**Environment info**\r\n- OS: Linux\r\n- Python version: 3.7.9\r\n- Sphinx version: 3.2.1/3.3.0\r\n- Sphinx extensions:\r\n    - 'sphinx.ext.autodoc',\r\n    - 'sphinx.ext.coverage',\r\n    - 'sphinx.ext.napoleon',\r\n    - 'recommonmark',\r\n    - 'sphinx.ext.viewcode',\r\n    - 'sphinx_markdown_tables',\r\n    - 'sphinx_copybutton'\r\n\r\n\r\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsphinx/ext/autodoc/__init__.py\n  function: ClassDocumenter.get_overloaded_signatures\n\nsphinx/pycode/__init__.py\n  function: ModuleAnalyzer.__init__\n  function: ModuleAnalyzer.parse\n"
    }
  ]
}