{
  "original_problem": {
    "instance_id": "sphinx-doc__sphinx-8801",
    "repo": "sphinx-doc/sphinx",
    "created_at": "2021-01-31T11:12:59Z",
    "problem_statement": "autodoc: The annotation only member in superclass is treated as \"undocumented\"\n**Describe the bug**\r\nautodoc: The annotation only member in superclass is treated as \"undocumented\".\r\n\r\n**To Reproduce**\r\n\r\n```\r\n# example.py\r\nclass Foo:\r\n    \"\"\"docstring\"\"\"\r\n    attr1: int  #: docstring\r\n\r\n\r\nclass Bar(Foo):\r\n    \"\"\"docstring\"\"\"\r\n    attr2: str  #: docstring\r\n```\r\n```\r\n# index.rst\r\n.. autoclass:: example.Bar\r\n   :members:\r\n   :inherited-members:\r\n```\r\n\r\n`Bar.attr1` is not documented. It will be shown if I give `:undoc-members:` option to the autoclass directive call. It seems the attribute is treated as undocumented.\r\n\r\n**Expected behavior**\r\nIt should be shown.\r\n\r\n**Your project**\r\nNo\r\n\r\n**Screenshots**\r\nNo\r\n\r\n**Environment info**\r\n- OS: Mac\r\n- Python version: 3.9.1\r\n- Sphinx version: HEAD of 3.x\r\n- Sphinx extensions: sphinx.ext.autodoc\r\n- Extra tools: No\r\n\r\n**Additional context**\r\nNo\r\n\n",
    "patch": "diff --git a/sphinx/ext/autodoc/importer.py b/sphinx/ext/autodoc/importer.py\n--- a/sphinx/ext/autodoc/importer.py\n+++ b/sphinx/ext/autodoc/importer.py\n@@ -294,24 +294,35 @@ def get_class_members(subject: Any, objpath: List[str], attrgetter: Callable\n \n     try:\n         for cls in getmro(subject):\n+            try:\n+                modname = safe_getattr(cls, '__module__')\n+                qualname = safe_getattr(cls, '__qualname__')\n+                analyzer = ModuleAnalyzer.for_module(modname)\n+                analyzer.analyze()\n+            except AttributeError:\n+                qualname = None\n+                analyzer = None\n+            except PycodeError:\n+                analyzer = None\n+\n             # annotation only member (ex. attr: int)\n             for name in getannotations(cls):\n                 name = unmangle(cls, name)\n                 if name and name not in members:\n-                    members[name] = ObjectMember(name, INSTANCEATTR, class_=cls)\n+                    if analyzer and (qualname, name) in analyzer.attr_docs:\n+                        docstring = '\\n'.join(analyzer.attr_docs[qualname, name])\n+                    else:\n+                        docstring = None\n+\n+                    members[name] = ObjectMember(name, INSTANCEATTR, class_=cls,\n+                                                 docstring=docstring)\n \n             # append instance attributes (cf. self.attr1) if analyzer knows\n-            try:\n-                modname = safe_getattr(cls, '__module__')\n-                qualname = safe_getattr(cls, '__qualname__')\n-                analyzer = ModuleAnalyzer.for_module(modname)\n-                analyzer.analyze()\n+            if analyzer:\n                 for (ns, name), docstring in analyzer.attr_docs.items():\n                     if ns == qualname and name not in members:\n                         members[name] = ObjectMember(name, INSTANCEATTR, class_=cls,\n                                                      docstring='\\n'.join(docstring))\n-            except (AttributeError, PycodeError):\n-                pass\n     except AttributeError:\n         pass\n \n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_8200",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve Sphinx autodoc's handling of type annotations and require changes to how options are managed to prevent unintended documentation omissions."
      },
      {
        "idx": 2,
        "id": "similar_2044",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about default values in documentation, which is unrelated to the handling of annotation-only members in the current issue."
      },
      {
        "idx": 3,
        "id": "similar_2298",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "This issue deals with module import and class attribute documentation, which does not relate to annotation-only member handling."
      },
      {
        "idx": 4,
        "id": "similar_7821",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about a TypeError in function signature handling, which is not directly related to annotation-only member documentation."
      },
      {
        "idx": 5,
        "id": "similar_8534",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves alias class attribute documentation, which does not share the same root cause or fix strategy as the current issue."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Certain type aliases break type formatting in automodule",
        "issue_body": "**Describe the bug**\r\nIf `automodule` is applied to a module which defines a documented complex type alias, the type annotations on all attributes later in the module will be ignored.\r\n\r\n**To Reproduce**\r\nApply `automodule` to a module like the following:\r\n```\r\nimport typing\r\n\r\nAlias = typing.Union[int, float]\r\n\"\"\"a type alias\"\"\"\r\n\r\nclass Foo:\r\n    \"\"\"blah\"\"\"\r\n\r\n    bar: object\r\n    \"\"\"an attribute\"\"\"\r\n```\r\nThe generated documentation will not list any type for the attribute `bar`. Removing the definition of `Alias` causes the type of `bar` to be correctly rendered.\r\n\r\n**Expected behavior**\r\nThe presence of a type alias definition should not affect the display of type information for unrelated members.\r\n\r\n**Your project**\r\nHere is a tiny example project: [example3.zip](https://github.com/sphinx-doc/sphinx/files/5212082/example3.zip)\r\n\r\n**Environment info**\r\n- OS: macOS 10.14.6\r\n- Python version: 3.8.0\r\n- Sphinx version: 3.2.1 (also reproduced on the current 3.x branch)\r\n- Sphinx extensions:  `sphinx.ext.autodoc`\r\n\r\n**Additional context**\r\nThe reason for the bug is that `autodoc.GenericAliasDocumenter.add_directive_header` and `autodoc.TypeVarDocumenter.add_directive_header` use the line `self.options.annotation = SUPPRESS` to suppress the printing of the usual type information. Unfortunately, the `self.options` object can be shared across multiple documenters created as part of the same `automodule` directive, so mutating the options for one documenter affects all the others. One way to fix this is to change `autodoc.Documenter.__init__` to make a copy of the `Options` object, using the line `self.options = Options(directive.genopt)`. Making this change causes the bug described above to disappear.\r\n\r\nThanks to @altendky for helping me debug this problem.",
        "issue_id": 8200,
        "pr_number": 8274,
        "pr_title": "Fix #8200: autodoc: type aliases break type formatting",
        "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- refs: #8200 \r\n- The annotation option is shared between auto directives unexpectedly.\r\nIt causes supression of type annotations for objects after\r\nGenericAlias definition.\r\n",
        "issue_closed_at": "2020-10-04T14:44:10Z",
        "base_commit": "38bb3774643d779b708970f941f2b16d1ab81b89"
      },
      "summary": "### Summary:\n\nThis issue pertains to an unexpected behavior within the Sphinx documentation generation tool, specifically when using the `automodule` directive in conjunction with type aliases. When a module defines a complex type alias, it inadvertently causes the type annotations for subsequent attributes in the module to be disregarded in the generated documentation. This behavior is not aligned with user expectations, as type aliases should not interfere with the display of type information for unrelated members.\n\nKey symptoms include the absence of type annotations in the documentation output for attributes following a type alias definition, despite their presence in the source code. The problem was observed when using `sphinx.ext.autodoc`, a commonly used extension for automatic documentation generation from Python docstrings.\n\nThe affected components are the `autodoc.GenericAliasDocumenter` and `autodoc.TypeVarDocumenter` classes, which share an `Options` object across multiple documenters due to the current implementation. This shared state causes the suppression of type information across unrelated documenters when one documenter's options are altered.\n\nThe potential impact of this issue is significant for developers relying on accurate and complete documentation generation, especially in projects that utilize type annotations heavily for clarity and type checking. The severity is heightened when users depend on the Sphinx-generated documentation for understanding and maintaining complex codebases.\n\nTechnical details reveal that the problem arises due to the `self.options.annotation = SUPPRESS` line, which affects all documenters within the same `automodule` scope. The proposed solution involves modifying the `autodoc.Documenter.__init__` method to create a distinct `Options` object for each documenter, thereby isolating changes and preventing unintended side effects.",
      "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: Certain type aliases break type formatting in automodule\n\nBody:\n**Describe the bug**\r\nIf `automodule` is applied to a module which defines a documented complex type alias, the type annotations on all attributes later in the module will be ignored.\r\n\r\n**To Reproduce**\r\nApply `automodule` to a module like the following:\r\n```\r\nimport typing\r\n\r\nAlias = typing.Union[int, float]\r\n\"\"\"a type alias\"\"\"\r\n\r\nclass Foo:\r\n    \"\"\"blah\"\"\"\r\n\r\n    bar: object\r\n    \"\"\"an attribute\"\"\"\r\n```\r\nThe generated documentation will not list any type for the attribute `bar`. Removing the definition of `Alias` causes the type of `bar` to be correctly rendered.\r\n\r\n**Expected behavior**\r\nThe presence of a type alias definition should not affect the display of type information for unrelated members.\r\n\r\n**Your project**\r\nHere is a tiny example project: [example3.zip](https://github.com/sphinx-doc/sphinx/files/5212082/example3.zip)\r\n\r\n**Environment info**\r\n- OS: macOS 10.14.6\r\n- Python version: 3.8.0\r\n- Sphinx version: 3.2.1 (also reproduced on the current 3.x branch)\r\n- Sphinx extensions:  `sphinx.ext.autodoc`\r\n\r\n**Additional context**\r\nThe reason for the bug is that `autodoc.GenericAliasDocumenter.add_directive_header` and `autodoc.TypeVarDocumenter.add_directive_header` use the line `self.options.annotation = SUPPRESS` to suppress the printing of the usual type information. Unfortunately, the `self.options` object can be shared across multiple documenters created as part of the same `automodule` directive, so mutating the options for one documenter affects all the others. One way to fix this is to change `autodoc.Documenter.__init__` to make a copy of the `Options` object, using the line `self.options = Options(directive.genopt)`. Making this change causes the bug described above to disappear.\r\n\r\nThanks to @altendky for helping me debug this problem.\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: SlotsAttributeDocumenter.can_document_member\n  function: SlotsAttributeDocumenter.can_document_member\n"
    },
    {
      "similar_issue": {
        "issue_title": "None by by default for instance attributes?",
        "issue_body": "When I'm included docstrings for instance attributes in the `__init__` of a class then using autoclass, I always end up with\n\n```\nattr = None\n    Documentation of attr\n```\n\ndue to this line\n\nhttps://github.com/sphinx-doc/sphinx/blob/add4c2467d9f98cadadff51593ca1727b4a81ca1/sphinx/ext/autodoc.py#L1465\n\nIs there a use case for documenting the `= None`. Can it just always be suppressed? There's no way right now to pass a `annotation` option to autoclass AFAICT.\n",
        "issue_id": 2044,
        "pr_number": 7515,
        "pr_title": "Close #2044: autodoc: Suppress default value for instance attributes",
        "pr_body": "### Feature or Bugfix\r\n- Feature\r\n- Bugfix\r\n\r\n### Purpose\r\n- refs: #2044 \r\n- This also fixes uninitialized global variables.",
        "issue_closed_at": "2020-04-23T12:57:37Z",
        "base_commit": "12cb90c3fa5451e2c99100d8ce1d4d0a8bb7f527"
      },
      "summary": "### Summary:\nThis issue pertains to the automatic documentation generation process in a software library used for creating documentation from Python code. Specifically, it involves the behavior of a documentation tool, Sphinx, which adds a default value of `None` to instance attributes when generating documentation via its `autoclass` feature. This occurs when docstrings are included for instance attributes within a class's `__init__` method.\n\n1. **Problem Description in General Terms**: The problem arises from the inclusion of an unwanted default value (`= None`) in the generated documentation for class instance attributes. This behavior is due to a specific line of code in the Sphinx autodoc extension that automatically appends the `= None` to attribute documentation. The issue questions the necessity of this default behavior and suggests its suppression.\n\n2. **Key Symptoms and Behaviors Observed**: Users of the Sphinx autodoc feature observe that instance attributes documented in the `__init__` method are presented with an appended `= None` in the output documentation. This behavior is consistent and unconfigurable, leading to potentially misleading documentation output.\n\n3. **Affected Components or Systems**: The main component affected is the Sphinx documentation tool, specifically the `autodoc` extension, which handles automatic documentation generation for Python classes and their attributes.\n\n4. **Potential Impact or Severity**: The impact of this issue is primarily on the clarity and accuracy of the generated documentation. By including `= None`, the documentation might inaccurately represent the intended default value or state of instance attributes, leading to confusion for users relying on the generated documentation for understanding class behavior.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The issue stems from the lack of an option to suppress or modify the automatic inclusion of `= None` for instance attributes in the `autoclass` directive of Sphinx. The underlying cause is traced to a specific line in the Sphinx `autodoc.py` file, and the absence of a configurable `annotation` option to alter this behavior. The recent code changes likely introduced additional flexibility or controls to address this documentation behavior issue.",
      "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: None by by default for instance attributes?\n\nBody:\nWhen I'm included docstrings for instance attributes in the `__init__` of a class then using autoclass, I always end up with\n\n```\nattr = None\n    Documentation of attr\n```\n\ndue to this line\n\nhttps://github.com/sphinx-doc/sphinx/blob/add4c2467d9f98cadadff51593ca1727b4a81ca1/sphinx/ext/autodoc.py#L1465\n\nIs there a use case for documenting the `= None`. Can it just always be suppressed? There's no way right now to pass a `annotation` option to autoclass AFAICT.\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: identity\n  function: PropertyDocumenter.add_directive_header\n  function: SlotsAttributeDocumenter.import_object\n  function: PropertyDocumenter.add_directive_header\n  function: SlotsAttributeDocumenter.import_object\n"
    },
    {
      "similar_issue": {
        "issue_title": "automodule fails to document a class attribute",
        "issue_body": "The directive automodule:: fails to document a class attribute under the following conditions:\n\nModule mod1 defines a class C:\n\n``` python\nclass C(object):\n    class_attr = 42\n    \"\"\"This is the class attribute class_attr\"\"\"\n```\n\nModule mod2 imports C from mod1:\n\n``` python\nfrom mod1 import C\n__all__ = ('C',)  # required to trigger the bug\n```\n\nNow document module mod2 using automodule:\n\n```\n.. automodule:: mod2\n   :members:\n```\n\nThe resulting documentation won't contain the doc string for the class attribute class_attr.\n\nThe bug is caused by a call of  class_documenter.generate() with the optional arguments\n`check_module=False` and `real_modname=\"mod2\"`. This causes the analyser to look for the source of class C in mod2 instead of mod1. As a consequence it doesn't find the doc-string of class_attr and fails to document it.\n\nI'll create a pull request with a test case and a fix.\n",
        "issue_id": 2298,
        "pr_number": 2299,
        "pr_title": "Fix #2298: automodule fails to document a class attribute.",
        "pr_body": "This pull request adds a test case for bug #2298 (commit de356149cd) and a fix (commit c44608234d).\n\nI didn't create a new test module but extended test_ext_viewcode, because the sphinx dev guide recommends it for performance reasons. The test fails until the second commit get applied.\n\nMy fix is not the only possible fix, but a fairly simple one. It surely needs to be reviewed. Especially I'm not completely sure about its impact on extension classes written in C.\n",
        "issue_closed_at": "2017-11-11T16:53:43Z",
        "base_commit": "bdc230b1ccc189989789f82a55023f369410309d"
      },
      "summary": "### Summary: This issue pertains to a documentation generation tool's inability to correctly document class attributes when using the `automodule::` directive under specific conditions. The problem arises when a class defined in one module is imported into another module, and the `automodule::` directive is used on the importing module to automatically generate documentation. Specifically, if the importing module's `__all__` attribute is used to include the class, the documentation tool fails to locate and document the class attribute's docstring. \n\nKey symptoms include the absence of the expected documentation for class attributes in the generated output, despite the presence of docstrings in the source code. The affected component is the `automodule` directive within the Sphinx documentation generation framework, particularly impacting the class attribute documentation process.\n\nThe potential impact of this issue includes incomplete or inaccurate documentation, which can hinder developers' understanding of the codebase, especially when relying on autogenerated documentation for large projects. The severity may vary based on how heavily a project relies on class attribute documentation.\n\nTechnically, the issue is traced to the function call `class_documenter.generate()` with the arguments `check_module=False` and `real_modname` set to the importing module. This setup causes the documentation tool to incorrectly search for the source of the class in the wrong module, leading to the failure in locating the docstring for the class attribute. The fix involves adjusting this behavior to ensure that the correct module is referenced during the documentation generation process.\n\nChanges were made to the file `sphinx/ext/autodoc.py`, specifically within the function `AttributeDocumenter.document_members`, to address this issue.",
      "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: automodule fails to document a class attribute\n\nBody:\nThe directive automodule:: fails to document a class attribute under the following conditions:\n\nModule mod1 defines a class C:\n\n``` python\nclass C(object):\n    class_attr = 42\n    \"\"\"This is the class attribute class_attr\"\"\"\n```\n\nModule mod2 imports C from mod1:\n\n``` python\nfrom mod1 import C\n__all__ = ('C',)  # required to trigger the bug\n```\n\nNow document module mod2 using automodule:\n\n```\n.. automodule:: mod2\n   :members:\n```\n\nThe resulting documentation won't contain the doc string for the class attribute class_attr.\n\nThe bug is caused by a call of  class_documenter.generate() with the optional arguments\n`check_module=False` and `real_modname=\"mod2\"`. This causes the analyser to look for the source of class C in mod2 instead of mod1. As a consequence it doesn't find the doc-string of class_attr and fails to document it.\n\nI'll create a pull request with a test case and a fix.\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.py\n  function: AttributeDocumenter.document_members\n"
    },
    {
      "similar_issue": {
        "issue_title": "TypeError: can't set attributes of built-in/extension type 'list'",
        "issue_body": "Previous issue: https://github.com/sphinx-doc/sphinx/issues/7791\r\n\r\n**Describe the bug**\r\nRunning sphinx-build after sphinx-apidoc on our codebase results in the error message:\r\n\r\n```\r\n  File \"/home/danielk/.local/lib/python3.7/site-packages/sphinx/ext/autodoc/__init__.py\", line 1240, in annotate_to_first_argument\r\n    func.__signature__ = sig.replace(parameters=params)  # type: ignore\r\nTypeError: can't set attributes of built-in/extension type 'list'\r\n```\r\n\r\n**To Reproduce**\r\nSteps to reproduce the behavior:\r\n\r\nRun `make html` in project folder\r\n\r\n**Expected behavior**\r\nNo error\r\n\r\n**Your project**\r\n\r\nn/a\r\n\r\n**Screenshots**\r\nIf applicable, add screenshots to help explain your problem.\r\n\r\n**Environment info**\r\n- OS: Gentoo Linux, KDE 19.12.3, Plasma 5.70\r\n- Python version: 3.7.7\r\n- Sphinx version: See below\r\n- Sphinx extensions: See below\r\n- Extra tools: n/a\r\n\r\n```\r\nalabaster                          0.7.12            \r\nautodoc                            0.5.0             \r\nBabel                              2.8.0             \r\nbeautifulsoup4                     4.9.1             \r\nBrotli                             1.0.7             \r\nbsddb3                             6.2.7             \r\ncertifi                            2020.4.5.1        \r\ncffi                               1.14.0            \r\nchardet                            3.0.4             \r\ncracklib                           2.9.7             \r\ncryptacular                        1.4.1             /home/danielk/Development/cryptacular/src/cryptacular\r\ncryptography                       2.8               \r\nCython                             0.29.15           \r\ndecorator                          4.4.2             \r\ndistro                             1.0.4             \r\ndocutils                           0.16              \r\nextras                             1.0.0             \r\nfile-magic                         0.4.0             \r\nfixtures                           3.0.0             \r\nFormEncode                         1.3.1             \r\ngdbus-codegen                      2.62.6            \r\ngemato                             14.3              \r\ngentoolkit                         0.4.8             \r\ngpg                                1.13.0            \r\ngpodder                            3.10.5            \r\nhtml5lib                           1.0.1             \r\nidna                               2.8               \r\nimagesize                          1.1.0             \r\nisodate                            0.6.0             \r\nisort                              4.3.15            \r\njava-config                        2.2.0             \r\nJinja2                             2.11.1            \r\nlayman                             2.4.3             \r\nlensfun                            0.3.2             \r\nlibsass                            0.20.0            \r\nlinecache2                         1.0.0             \r\nlxml                               4.5.0             \r\nM2Crypto                           0.31.0            \r\nMako                               1.1.2             \r\nMarkdown                           2.4.1             \r\nMarkups                            3.0.0             \r\nMarkupSafe                         1.1.1             \r\nmercurial                          5.3.2             \r\nmeson                              0.52.1            \r\nmimeparse                          1.6.0             \r\nmock                               4.0.2             \r\nMomoko                             2.2.5.1           \r\nmygpoclient                        1.8               \r\nnetlink                            1.0               \r\nnotify2                            0.3.1             \r\nnumpy                              1.17.4            \r\nolefile                            0.46              \r\npackaging                          20.3              \r\npbkdf2                             1.3               \r\npbr                                5.1.1             \r\npdoc                               0.3.2             \r\nPillow                             7.0.0             \r\npip                                20.0.2            \r\nply                                3.11              \r\npodcastparser                      0.6.4             \r\nportage                            2.3.99            \r\npsycopg2                           2.8.5             \r\npsycopg2-binary                    2.8.5             \r\npwquality                          1.4.2             \r\npycairo                            1.18.2            \r\nPycco                              0.6.0             \r\npycountry                          19.8.18           \r\npycparser                          2.20              \r\npycryptodome                       3.9.4             \r\npyelftools                         0.25              \r\npyenchant                          2.0.0             \r\nPygments                           2.5.2             \r\nPyGObject                          3.34.0            \r\npyOpenSSL                          19.1.0            \r\npyparsing                          2.4.6             \r\npyportmidi                         0.0.7             \r\nPyQt5                              5.14.1            \r\nPyQt5-sip                          4.19.21           \r\nPyQtWebEngine                      5.14.0            \r\npyrsistent                         0.15.6            \r\nPySocks                            1.7.1             \r\npystache                           0.5.4             \r\npython-markdown-math               0.6               \r\npython-mimeparse                   1.6.0             \r\npython-subunit                     1.2.0             \r\npytz                               2019.3            \r\npyxdg                              0.26              \r\nPyYAML                             5.3.1             \r\nrdflib                             4.2.2             \r\nreportlab                          3.5.13            \r\nrequests                           2.23.0            \r\nReText                             7.0.4             \r\nscour                              0.37              \r\nsetuptools                         44.1.0            \r\nsimplejson                         3.17.0            \r\nsip                                4.19.21           \r\nsix                                1.14.0            \r\nsmartypants                        2.0.1             \r\nsnowballstemmer                    2.0.0             \r\nsoupsieve                          2.0.1             \r\nSphinx                             3.1.0             \r\nsphinx-rtd-theme                   0.4.3             \r\nsphinx-rtd-theme-http              1.0.0             \r\nsphinxcontrib-apidoc               0.3.0             \r\nsphinxcontrib-applehelp            1.0.2             \r\nsphinxcontrib-autodoc-doxygen      0.6.0             \r\nsphinxcontrib-autodoc-filterparams 0.0.1             \r\nsphinxcontrib-devhelp              1.0.2             \r\nsphinxcontrib-htmlhelp             1.0.3             \r\nsphinxcontrib-httpdomain           1.7.0             \r\nsphinxcontrib-jsmath               1.0.1             \r\nsphinxcontrib-mockautodoc          0.0.1.dev20130518 \r\nsphinxcontrib-qthelp               1.0.3             \r\nsphinxcontrib-serializinghtml      1.1.3             \r\nssl-fetch                          0.4               \r\ntesttools                          2.3.0             \r\ntornado                            5.1.1             \r\ntraceback2                         1.4.0             \r\ntyped-ast                          1.4.1             \r\nunittest2                          1.1.0             \r\nurllib3                            1.25.8            \r\nwaitress                           1.4.4             \r\nwebencodings                       0.5.1             \r\nWebOb                              1.8.6             \r\nWebTest                            2.0.35            \r\nyoutube-dl                         2020.5.29         \r\nzstandard                          0.13.0 \r\n```\r\n\r\n\r\n\r\n**Additional context**\r\n\r\n```\r\n\r\nRunning Sphinx v3.1.0\r\nbuilding [mo]: targets for 0 po files that are out of date\r\nbuilding [html]: targets for 41 source files that are out of date\r\nupdating environment: [new config] 41 added, 0 changed, 0 removed\r\nreading sources... [ 87%] ... Exception occurred:\r\n  File \"/home/danielk/.local/lib/python3.7/site-packages/sphinx/ext/autodoc/__init__.py\", line 1240, in annotate_to_first_argument\r\n    func.__signature__ = sig.replace(parameters=params)  # type: ignore\r\nTypeError: can't set attributes of built-in/extension type 'list'\r\nThe full traceback has been saved in /tmp/sphinx-err-lf0wsvvp.log\r\n\r\n, if you want to report the issue to the developers.\r\nPlease also report this if it was a user error, so that a better error message can be provided next time.\r\nA bug report can be filed in the tracker at <https://github.com/sphinx-doc/sphinx/issues>. Thanks!\r\nmake[1]: *** [Makefile:20: html] Error 2\r\nmake[1]: Leaving directory '/home/danielk/Development/docs'\r\nmake: *** [Makefile:85: docs] Error 2\r\n```\r\n\r\n[sphinx-err-lf0wsvvp.log](https://github.com/sphinx-doc/sphinx/files/4766780/sphinx-err-lf0wsvvp.log)",
        "issue_id": 7821,
        "pr_number": 7823,
        "pr_title": "Fix #7821: autodoc: TypeError is raised for overloaded C-ext function",
        "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- refs: #7821 ",
        "issue_closed_at": "2020-06-14T02:48:20Z",
        "base_commit": "46f79c55e1242ae8bb49b14c0a9e226d119460e5"
      },
      "summary": "### Summary:\nThis issue is related to a TypeError occurring during the use of the Sphinx documentation generator, specifically when running `sphinx-build` after `sphinx-apidoc`. The error message indicates that there is an attempt to set attributes on a built-in or extension type 'list', which is not allowed in Python. The problem occurs in the `annotate_to_first_argument` function within Sphinx's autodoc extension module.\n\n1. **Problem Description:**\n   The error arises when Sphinx attempts to modify the `__signature__` attribute of a function using the `sig.replace(parameters=params)` method call. This operation is targeting an immutable type, resulting in a TypeError. The function's signature is being manipulated incorrectly, leading to the failure.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - The error manifests as a TypeError with the message: \"can't set attributes of built-in/extension type 'list'\".\n   - The traceback points to the `annotate_to_first_argument` function in the autodoc module.\n   - The build process halts with an error, preventing the generation of HTML documentation.\n\n3. **Affected Components or Systems:**\n   - The Sphinx autodoc extension is the primary component affected.\n   - The error impacts users running Sphinx version 3.1.0 on a Python 3.7.7 environment.\n\n4. **Potential Impact or Severity:**\n   - This issue prevents successful documentation generation, which can hinder development processes reliant on automated documentation.\n   - It affects the reliability of Sphinx in environments using the autodoc extension for API documentation.\n\n5. **Relevant Technical Details Abstracted:**\n   - The problem is rooted in the handling of function signatures within the Sphinx autodoc module.\n   - The code attempts to set a signature on a function's attribute that is inherently immutable or not intended for modification.\n   - This indicates a need for a patch to handle such attribute manipulations correctly, ensuring the attribute type is mutable or the operation is performed safely.\n\nThe resolution likely involved modifying the `annotate_to_first_argument` function to ensure compatibility with the types being manipulated, preventing the attempt to set immutable attributes directly.",
      "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: TypeError: can't set attributes of built-in/extension type 'list'\n\nBody:\nPrevious issue: https://github.com/sphinx-doc/sphinx/issues/7791\r\n\r\n**Describe the bug**\r\nRunning sphinx-build after sphinx-apidoc on our codebase results in the error message:\r\n\r\n```\r\n  File \"/home/danielk/.local/lib/python3.7/site-packages/sphinx/ext/autodoc/__init__.py\", line 1240, in annotate_to_first_argument\r\n    func.__signature__ = sig.replace(parameters=params)  # type: ignore\r\nTypeError: can't set attributes of built-in/extension type 'list'\r\n```\r\n\r\n**To Reproduce**\r\nSteps to reproduce the behavior:\r\n\r\nRun `make html` in project folder\r\n\r\n**Expected behavior**\r\nNo error\r\n\r\n**Your project**\r\n\r\nn/a\r\n\r\n**Screenshots**\r\nIf applicable, add screenshots to help explain your problem.\r\n\r\n**Environment info**\r\n- OS: Gentoo Linux, KDE 19.12.3, Plasma 5.70\r\n- Python version: 3.7.7\r\n- Sphinx version: See below\r\n- Sphinx extensions: See below\r\n- Extra tools: n/a\r\n\r\n```\r\nalabaster                          0.7.12            \r\nautodoc                            0.5.0             \r\nBabel                              2.8.0             \r\nbeautifulsoup4                     4.9.1             \r\nBrotli                             1.0.7             \r\nbsddb3                             6.2.7             \r\ncertifi                            2020.4.5.1        \r\ncffi                               1.14.0            \r\nchardet                            3.0.4             \r\ncracklib                           2.9.7             \r\ncryptacular                        1.4.1             /home/danielk/Development/cryptacular/src/cryptacular\r\ncryptography                       2.8               \r\nCython                             0.29.15           \r\ndecorator                          4.4.2             \r\ndistro                             1.0.4             \r\ndocutils                           0.16              \r\nextras                             1.0.0             \r\nfile-magic                         0.4.0             \r\nfixtures                           3.0.0             \r\nFormEncode                         1.3.1             \r\ngdbus-codegen                      2.62.6            \r\ngemato                             14.3              \r\ngentoolkit                         0.4.8             \r\ngpg                                1.13.0            \r\ngpodder                            3.10.5            \r\nhtml5lib                           1.0.1             \r\nidna                               2.8               \r\nimagesize                          1.1.0             \r\nisodate                            0.6.0             \r\nisort                              4.3.15            \r\njava-config                        2.2.0             \r\nJinja2                             2.11.1            \r\nlayman                             2.4.3             \r\nlensfun                            0.3.2             \r\nlibsass                            0.20.0            \r\nlinecache2                         1.0.0             \r\nlxml                               4.5.0             \r\nM2Crypto                           0.31.0            \r\nMako                               1.1.2             \r\nMarkdown                           2.4.1             \r\nMarkups                            3.0.0             \r\nMarkupSafe                         1.1.1             \r\nmercurial                          5.3.2             \r\nmeson                              0.52.1            \r\nmimeparse                          1.6.0             \r\nmock                               4.0.2             \r\nMomoko                             2.2.5.1           \r\nmygpoclient                        1.8               \r\nnetlink                            1.0               \r\nnotify2                            0.3.1             \r\nnumpy                              1.17.4            \r\nolefile                            0.46              \r\npackaging                          20.3              \r\npbkdf2                             1.3               \r\npbr                                5.1.1             \r\npdoc                               0.3.2             \r\nPillow                             7.0.0             \r\npip                                20.0.2            \r\nply                                3.11              \r\npodcastparser                      0.6.4             \r\nportage                            2.3.99            \r\npsycopg2                           2.8.5             \r\npsycopg2-binary                    2.8.5             \r\npwquality                          1.4.2             \r\npycairo                            1.18.2            \r\nPycco                              0.6.0             \r\npycountry                          19.8.18           \r\npycparser                          2.20              \r\npycryptodome                       3.9.4             \r\npyelftools                         0.25              \r\npyenchant                          2.0.0             \r\nPygments                           2.5.2             \r\nPyGObject                          3.34.0            \r\npyOpenSSL                          19.1.0            \r\npyparsing                          2.4.6             \r\npyportmidi                         0.0.7             \r\nPyQt5                              5.14.1            \r\nPyQt5-sip                          4.19.21           \r\nPyQtWebEngine                      5.14.0            \r\npyrsistent                         0.15.6            \r\nPySocks                            1.7.1             \r\npystache                           0.5.4             \r\npython-markdown-math               0.6               \r\npython-mimeparse                   1.6.0             \r\npython-subunit                     1.2.0             \r\npytz                               2019.3            \r\npyxdg                              0.26              \r\nPyYAML                             5.3.1             \r\nrdflib                             4.2.2             \r\nreportlab                          3.5.13            \r\nrequests                           2.23.0            \r\nReText                             7.0.4             \r\nscour                              0.37              \r\nsetuptools                         44.1.0            \r\nsimplejson                         3.17.0            \r\nsip                                4.19.21           \r\nsix                                1.14.0            \r\nsmartypants                        2.0.1             \r\nsnowballstemmer                    2.0.0             \r\nsoupsieve                          2.0.1             \r\nSphinx                             3.1.0             \r\nsphinx-rtd-theme                   0.4.3             \r\nsphinx-rtd-theme-http              1.0.0             \r\nsphinxcontrib-apidoc               0.3.0             \r\nsphinxcontrib-applehelp            1.0.2             \r\nsphinxcontrib-autodoc-doxygen      0.6.0             \r\nsphinxcontrib-autodoc-filterparams 0.0.1             \r\nsphinxcontrib-devhelp              1.0.2             \r\nsphinxcontrib-htmlhelp             1.0.3             \r\nsphinxcontrib-httpdomain           1.7.0             \r\nsphinxcontrib-jsmath               1.0.1             \r\nsphinxcontrib-mockautodoc          0.0.1.dev20130518 \r\nsphinxcontrib-qthelp               1.0.3             \r\nsphinxcontrib-serializinghtml      1.1.3             \r\nssl-fetch                          0.4               \r\ntesttools                          2.3.0             \r\ntornado                            5.1.1             \r\ntraceback2                         1.4.0             \r\ntyped-ast                          1.4.1             \r\nunittest2                          1.1.0             \r\nurllib3                            1.25.8            \r\nwaitress                           1.4.4             \r\nwebencodings                       0.5.1             \r\nWebOb                              1.8.6             \r\nWebTest                            2.0.35            \r\nyoutube-dl                         2020.5.29         \r\nzstandard                          0.13.0 \r\n```\r\n\r\n\r\n\r\n**Additional context**\r\n\r\n```\r\n\r\nRunning Sphinx v3.1.0\r\nbuilding [mo]: targets for 0 po files that are out of date\r\nbuilding [html]: targets for 41 source files that are out of date\r\nupdating environment: [new config] 41 added, 0 changed, 0 removed\r\nreading sources... [ 87%] ... Exception occurred:\r\n  File \"/home/danielk/.local/lib/python3.7/site-packages/sphinx/ext/autodoc/__init__.py\", line 1240, in annotate_to_first_argument\r\n    func.__signature__ = sig.replace(parameters=params)  # type: ignore\r\nTypeError: can't set attributes of built-in/extension type 'list'\r\nThe full traceback has been saved in /tmp/sphinx-err-lf0wsvvp.log\r\n\r\n, if you want to report the issue to the developers.\r\nPlease also report this if it was a user error, so that a better error message can be provided next time.\r\nA bug report can be filed in the tracker at <https://github.com/sphinx-doc/sphinx/issues>. Thanks!\r\nmake[1]: *** [Makefile:20: html] Error 2\r\nmake[1]: Leaving directory '/home/danielk/Development/docs'\r\nmake: *** [Makefile:85: docs] Error 2\r\n```\r\n\r\n[sphinx-err-lf0wsvvp.log](https://github.com/sphinx-doc/sphinx/files/4766780/sphinx-err-lf0wsvvp.log)\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: MethodDocumenter.annotate_to_first_argument\n  function: MethodDocumenter.annotate_to_first_argument\n"
    },
    {
      "similar_issue": {
        "issue_title": "autodoc: autoattribute directive can't create document for commented attribute in alias class",
        "issue_body": "**Describe the bug**\r\nautodoc: autoattribute directive can't create document for commented attribute in alias class\r\n\r\n**To Reproduce**\r\n\r\n```\r\n# example.py\r\n\r\nclass Foo:\r\n    def __init__(self):\r\n        self.attr = None  #: docstring\r\n\r\nAlias = Foo\r\n```\r\n```\r\n# index.rst\r\n\r\n.. autoattribute:: example.Alias.attr\r\n```\r\n\r\nThis example causes ImportError on generating a document.\r\n\r\n**Expected behavior**\r\nBuild successfully.\r\n\r\n**Your project**\r\nNo\r\n\r\n**Screenshots**\r\nNo\r\n\r\n**Environment info**\r\n- OS: Mac\r\n- Python version: 3.9.1\r\n- Sphinx version: HEAD of 3.x\r\n- Sphinx extensions: sphinx.ext.autodoc\r\n- Extra tools: No\r\n\r\n**Additional context**\r\nNo",
        "issue_id": 8534,
        "pr_number": 8543,
        "pr_title": "Fix #8534: autoattribute failed to document a commented attribute in alias dervied class",
        "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- Additional fix for https://github.com/sphinx-doc/sphinx/pull/8540#discussion_r543556450\r\n- This contains https://github.com/sphinx-doc/sphinx/pull/8542",
        "issue_closed_at": "2020-12-16T14:47:26Z",
        "base_commit": "beeab6ced4e0441e84b517f0f4e54472a83f30b7"
      },
      "summary": "### Summary:\n\nThis issue is related to the Sphinx documentation generator, specifically within the `autodoc` extension, which is used to automatically generate documentation from docstrings in Python code. The problem arises when using the `autoattribute` directive to document attributes of an alias class. In the given example, an attribute `attr` is documented in a class `Foo`, and an alias `Alias` is created for this class. When attempting to use the `autoattribute` directive to generate documentation for `Alias.attr`, an `ImportError` occurs during the documentation build process.\n\nKey symptoms include the failure of the documentation build process when trying to document attributes of an alias class using the `autoattribute` directive. The affected components are the Sphinx `autodoc` extension, particularly the handling of attributes in alias classes.\n\nThe potential impact of this issue is that users of Sphinx, who rely on the `autodoc` extension to automate documentation generation, may encounter errors and be unable to document their code as intended, specifically when dealing with class aliases. This could hinder the documentation process and affect the usability of documentation for projects that use alias classes.\n\nRelevant technical details include the use of Python 3.9.1, Sphinx version 3.x, and the `sphinx.ext.autodoc` extension. The issue is observed on the macOS operating system. The problem seems to stem from the `ClassDocumenter.__init__` function within the `sphinx/ext/autodoc/__init__.py` file, which may need adjustments to correctly handle attributes in alias classes to prevent the `ImportError` and allow successful documentation generation.",
      "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: autodoc: autoattribute directive can't create document for commented attribute in alias class\n\nBody:\n**Describe the bug**\r\nautodoc: autoattribute directive can't create document for commented attribute in alias class\r\n\r\n**To Reproduce**\r\n\r\n```\r\n# example.py\r\n\r\nclass Foo:\r\n    def __init__(self):\r\n        self.attr = None  #: docstring\r\n\r\nAlias = Foo\r\n```\r\n```\r\n# index.rst\r\n\r\n.. autoattribute:: example.Alias.attr\r\n```\r\n\r\nThis example causes ImportError on generating a document.\r\n\r\n**Expected behavior**\r\nBuild successfully.\r\n\r\n**Your project**\r\nNo\r\n\r\n**Screenshots**\r\nNo\r\n\r\n**Environment info**\r\n- OS: Mac\r\n- Python version: 3.9.1\r\n- Sphinx version: HEAD of 3.x\r\n- Sphinx extensions: sphinx.ext.autodoc\r\n- Extra tools: No\r\n\r\n**Additional context**\r\nNo\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.__init__\n"
    }
  ]
}