{
  "original_problem": {
    "instance_id": "sphinx-doc__sphinx-10325",
    "repo": "sphinx-doc/sphinx",
    "created_at": "2022-04-02T17:05:02Z",
    "problem_statement": "inherited-members should support more than one class\n**Is your feature request related to a problem? Please describe.**\r\nI have two situations:\r\n- A class inherits from multiple other classes. I want to document members from some of the base classes but ignore some of the base classes\r\n- A module contains several class definitions that inherit from different classes that should all be ignored (e.g., classes that inherit from list or set or tuple). I want to ignore members from list, set, and tuple while documenting all other inherited members in classes in the module.\r\n\r\n**Describe the solution you'd like**\r\nThe :inherited-members: option to automodule should accept a list of classes. If any of these classes are encountered as base classes when instantiating autoclass documentation, they should be ignored.\r\n\r\n**Describe alternatives you've considered**\r\nThe alternative is to not use automodule, but instead manually enumerate several autoclass blocks for a module. This only addresses the second bullet in the problem description and not the first. It is also tedious for modules containing many class definitions.\r\n\r\n\n",
    "patch": "diff --git a/sphinx/ext/autodoc/__init__.py b/sphinx/ext/autodoc/__init__.py\n--- a/sphinx/ext/autodoc/__init__.py\n+++ b/sphinx/ext/autodoc/__init__.py\n@@ -109,12 +109,14 @@ def exclude_members_option(arg: Any) -> Union[object, Set[str]]:\n     return {x.strip() for x in arg.split(',') if x.strip()}\n \n \n-def inherited_members_option(arg: Any) -> Union[object, Set[str]]:\n+def inherited_members_option(arg: Any) -> Set[str]:\n     \"\"\"Used to convert the :members: option to auto directives.\"\"\"\n     if arg in (None, True):\n-        return 'object'\n+        return {'object'}\n+    elif arg:\n+        return set(x.strip() for x in arg.split(','))\n     else:\n-        return arg\n+        return set()\n \n \n def member_order_option(arg: Any) -> Optional[str]:\n@@ -680,9 +682,11 @@ def filter_members(self, members: ObjectMembers, want_all: bool\n         ``autodoc-skip-member`` event.\n         \"\"\"\n         def is_filtered_inherited_member(name: str, obj: Any) -> bool:\n+            inherited_members = self.options.inherited_members or set()\n+\n             if inspect.isclass(self.object):\n                 for cls in self.object.__mro__:\n-                    if cls.__name__ == self.options.inherited_members and cls != self.object:\n+                    if cls.__name__ in inherited_members and cls != self.object:\n                         # given member is a member of specified *super class*\n                         return True\n                     elif name in cls.__dict__:\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_10009",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about a systemic error with PySide6 resources and does not share a similar causal chain or fix strategy with the current issue."
      },
      {
        "idx": 2,
        "id": "similar_8146",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves incorrect handling of built-in objects in inheritance diagrams, which is unrelated to the current issue's focus on inherited members in documentation."
      },
      {
        "idx": 3,
        "id": "similar_8594",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve the Sphinx autodoc extension and incorrect handling of module members, suggesting transferable reasoning in handling member inclusion logic."
      },
      {
        "idx": 4,
        "id": "similar_2298",
        "decision": "Useful",
        "confidence": "High",
        "reason": "The issue deals with documenting class attributes across modules, similar to the current issue's focus on inherited members, indicating a shared causal chain."
      },
      {
        "idx": 5,
        "id": "similar_8567",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about incorrect association of instance attributes due to shared references, which does not align with the current issue's focus on inherited members."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "SystemError when trying to build a doc with Pyside6 resources",
        "issue_body": "### Describe the bug\n\nHi,\r\n\r\nWe have a fairly large project with the following folder structure:\r\n\r\n- docs\r\n- package\r\n- tests\r\n- ui\r\n  - \\_\\_init__.py\r\n  - resources\r\n    - gui.qrc\r\n    - icons\r\n       - icons1.png\r\n       - icon2.png\r\n       - ...\r\n\r\n\r\n`ui/resources` is actually not a valid Python package, but before running the GUI, we use the command `pyside6-rcc ui/resources/gui.qrc -o ui/resources.py`\r\n\r\nThe file `ui\\__init__.py` contains the line `from . import resources`\r\n\r\nWhen we build the doc with sphinx , we get the exception:\r\n\r\n```\r\n  File \"path\\to\\python\\lib\\inspect.py\", line 614, in getdoc\r\n    doc = object.__doc__\r\nSystemError: null argument to internal routine\r\n```\r\n\r\nThe log itself is not more useful either :\r\n\r\n\r\n```\r\n# Sphinx version: 4.3.2\r\n# Python version: 3.9.9 (CPython)\r\n# Docutils version: 0.16 release\r\n# Jinja2 version: 2.11.3\r\n# Last messages:\r\n#   Lecture des sources... [ 43%] package.module1.submodule1\r\n#   Lecture des sources... [ 45%] package.submodules\r\n#   Lecture des sources... [ 47%] index\r\n#   Lecture des sources... [ 50%] modules\r\n#   Lecture des sources... [ 52%] tests\r\n#   Lecture des sources... [ 54%] tests.test_module1\r\n#   Lecture des sources... [ 56%] tests.test_module2\r\n#   Lecture des sources... [ 58%] tests.test_module2.submodule1\r\n#   Lecture des sources... [ 60%] tests.test_module2.submodule2\r\n# Loaded extensions:\r\n#   sphinx.ext.mathjax (4.3.2) from path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\mathjax.py\r\n#   sphinxcontrib.applehelp (1.0.2) from path\\to\\venv\\lib\\site-packages\\sphinxcontrib\\applehelp\\__init__.py\r\n#   sphinxcontrib.devhelp (1.0.2) from path\\to\\venv\\lib\\site-packages\\sphinxcontrib\\devhelp\\__init__.py\r\n#   sphinxcontrib.htmlhelp (2.0.0) from path\\to\\venv\\lib\\site-packages\\sphinxcontrib\\htmlhelp\\__init__.py\r\n#   sphinxcontrib.serializinghtml (1.1.5) from path\\to\\venv\\lib\\site-packages\\sphinxcontrib\\serializinghtml\\__init__.py\r\n#   sphinxcontrib.qthelp (1.0.3) from path\\to\\venv\\lib\\site-packages\\sphinxcontrib\\qthelp\\__init__.py\r\n#   alabaster (0.7.12) from path\\to\\venv\\lib\\site-packages\\alabaster\\__init__.py\r\n#   sphinx_rtd_theme (unknown version) from path\\to\\venv\\lib\\site-packages\\sphinx_rtd_theme\\__init__.py\r\n#   sphinx.ext.autodoc.preserve_defaults (1.0) from path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\preserve_defaults.py\r\n#   sphinx.ext.autodoc.type_comment (4.3.2) from path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\type_comment.py\r\n#   sphinx.ext.autodoc (4.3.2) from path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\__init__.py\r\n#   matplotlib.sphinxext.plot_directive (3.5.0) from path\\to\\venv\\lib\\site-packages\\matplotlib\\sphinxext\\plot_directive.py\r\nTraceback (most recent call last):\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\cmd\\build.py\", line 280, in build_main\r\n    app.build(args.force_all, filenames)\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\application.py\", line 344, in build\r\n    self.builder.build_update()\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\builders\\__init__.py\", line 294, in build_update\r\n    self.build(to_build,\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\builders\\__init__.py\", line 308, in build\r\n    updated_docnames = set(self.read())\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\builders\\__init__.py\", line 415, in read\r\n    self._read_serial(docnames)\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\builders\\__init__.py\", line 436, in _read_serial\r\n    self.read_doc(docname)\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\builders\\__init__.py\", line 476, in read_doc\r\n    doctree = read_doc(self.app, self.env, self.env.doc2path(docname))\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\io.py\", line 189, in read_doc\r\n    pub.publish()\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\core.py\", line 217, in publish\r\n    self.document = self.reader.read(self.source, self.parser,\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\io.py\", line 109, in read\r\n    self.parse()\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\readers\\__init__.py\", line 77, in parse\r\n    self.parser.parse(self.input, document)\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\parsers.py\", line 101, in parse\r\n    self.statemachine.run(inputlines, document, inliner=self.inliner)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 170, in run\r\n    results = StateMachineWS.run(self, input_lines, input_offset,\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\statemachine.py\", line 241, in run\r\n    context, next_state, result = self.check_line(\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\statemachine.py\", line 459, in check_line\r\n    return method(match, context, next_state)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 2769, in underline\r\n    self.section(title, source, style, lineno - 1, messages)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 327, in section\r\n    self.new_subsection(title, lineno, messages)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 393, in new_subsection\r\n    newabsoffset = self.nested_parse(\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 281, in nested_parse\r\n    state_machine.run(block, input_offset, memo=self.memo,\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 196, in run\r\n    results = StateMachineWS.run(self, input_lines, input_offset)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\statemachine.py\", line 241, in run\r\n    context, next_state, result = self.check_line(\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\statemachine.py\", line 459, in check_line\r\n    return method(match, context, next_state)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 2769, in underline\r\n    self.section(title, source, style, lineno - 1, messages)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 327, in section\r\n    self.new_subsection(title, lineno, messages)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 393, in new_subsection\r\n    newabsoffset = self.nested_parse(\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 281, in nested_parse\r\n    state_machine.run(block, input_offset, memo=self.memo,\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 196, in run\r\n    results = StateMachineWS.run(self, input_lines, input_offset)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\statemachine.py\", line 241, in run\r\n    context, next_state, result = self.check_line(\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\statemachine.py\", line 459, in check_line\r\n    return method(match, context, next_state)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 2342, in explicit_markup\r\n    nodelist, blank_finish = self.explicit_construct(match)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 2354, in explicit_construct\r\n    return method(self, expmatch)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 2096, in directive\r\n    return self.run_directive(\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 2146, in run_directive\r\n    result = directive_instance.run()\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\directive.py\", line 162, in run\r\n    documenter.generate(more_content=self.content)\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\__init__.py\", line 984, in generate\r\n    self.document_members(all_members)\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\__init__.py\", line 842, in document_members\r\n    for (mname, member, isattr) in self.filter_members(members, want_all):\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\__init__.py\", line 723, in filter_members\r\n    doc = getdoc(member, self.get_attr, self.config.autodoc_inherit_docstrings,\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\util\\inspect.py\", line 912, in getdoc\r\n    doc = inspect.getdoc(obj)\r\n  File \"path\\to\\python\\lib\\inspect.py\", line 614, in getdoc\r\n    doc = object.__doc__\r\nSystemError: null argument to internal routine\r\n\r\n```\r\n\r\nWhen we build the doc from the sources, we get this error.\r\nWhen we build it after generating `ui\\resources.py`, we get this error\r\nWhen we build it after generating `ui\\resources.py` and deleting the folder `ui\\resources`, we get this error\r\nWhen we build it after deleting the `ui\\resources` and the file `ui\\resources.py`, it works\r\n\r\n\n\n### How to Reproduce\n\nI am trying to create a minimal reproducable example but my attempts failed so far\r\n\r\nThe doc itself was built running the following powershell script\r\n\r\n```\r\ncd .\\docs\r\n\r\n# Remove previously generated auto-doc and plots\r\nRemove-Item .\\source\\* -Include *.rst -Exclude index.rst\r\n.\\make.bat clean\r\n\r\n# Generate source files for documentation from docstrings\r\nsphinx-apidoc -f -o source/ ../\r\n\r\n# build documentation\r\n.\\make.bat html\r\n```\r\n\n\n### Expected behavior\n\nThe main issue I had is not the error itself, as we are going to change how we package the pyside6 resources to the gui to fix it, but the fact that neither the error message nor the log pointed towards the issue\r\n\r\nTo find the culprit, I started to delete folders of my projet until I managed to build the doc and finally find the culprit.\n\n### Your project\n\nStill working on a minimal reproducible example\n\n### Screenshots\n\n_No response_\n\n### OS\n\nWindows 10\n\n### Python version\n\n3.9.9\n\n### Sphinx version\n\n4.3.2\n\n### Sphinx extensions\n\nsphinx_rtd_theme, sphinx.ext.autodoc, matplotlib.sphinxext.plot_directive'\n\n### Extra tools\n\nPyside6==6.2.2.1\n\n### Additional context\n\nThanks a lot for providing a great documentation tool !",
        "issue_id": 10009,
        "pr_number": 10011,
        "pr_title": "Fix #10009: autodoc: Crashes if subject raises an error on getdoc()",
        "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- refs: #10009 ",
        "issue_closed_at": "2021-12-28T17:07:48Z",
        "base_commit": "8ddf3f09c62e2a4651458759fcc97e751ca63063"
      },
      "summary": "### Summary:\n\nThis issue involves a systemic error encountered when attempting to build documentation for a project utilizing PySide6 resources with Sphinx. The primary problem is a \"SystemError: null argument to internal routine\" that arises during documentation generation, specifically linked to Python's `inspect` module. The problem is attributed to the presence of a non-standard Python package structure, particularly within the `ui/resources` directory, which is not a valid Python package but is manipulated to include PySide6 resources. The error is consistently reproducible under several conditions that involve the existence of the `ui/resources` directory or its generated Python file, `ui/resources.py`.\n\nKey symptoms and behaviors include the consistent generation of a null argument error from the `inspect.getdoc` function within Sphinx's autodoc extension. Despite attempts to simplify the issue for reproducibility, the error persists unless both the directory and the generated file are removed. This indicates a deeper integration issue between the resource packaging method and the Sphinx autodoc process.\n\nAffected components include the Sphinx documentation builder, specifically its `autodoc` extension, and the Python `inspect` module used for extracting documentation strings. This issue impacts the documentation build process, potentially preventing successful documentation generation, which can be critical for project documentation and dissemination.\n\nThe potential impact is moderate to high, especially for projects relying on automated documentation generation for development and deployment workflows. The presence of such an error can significantly disrupt documentation processes, necessitating manual intervention or restructuring of resource packaging methods.\n\nRelevant technical details focus on the interaction between the PySide6 resource generation process and Sphinx's autodoc module, highlighting a gap in error reporting and diagnostic capabilities within these tools. The issue underscores the need for improved error messaging and diagnostic tools in Sphinx to better identify and address such integration challenges.",
      "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: SystemError when trying to build a doc with Pyside6 resources\n\nBody:\n### Describe the bug\n\nHi,\r\n\r\nWe have a fairly large project with the following folder structure:\r\n\r\n- docs\r\n- package\r\n- tests\r\n- ui\r\n  - \\_\\_init__.py\r\n  - resources\r\n    - gui.qrc\r\n    - icons\r\n       - icons1.png\r\n       - icon2.png\r\n       - ...\r\n\r\n\r\n`ui/resources` is actually not a valid Python package, but before running the GUI, we use the command `pyside6-rcc ui/resources/gui.qrc -o ui/resources.py`\r\n\r\nThe file `ui\\__init__.py` contains the line `from . import resources`\r\n\r\nWhen we build the doc with sphinx , we get the exception:\r\n\r\n```\r\n  File \"path\\to\\python\\lib\\inspect.py\", line 614, in getdoc\r\n    doc = object.__doc__\r\nSystemError: null argument to internal routine\r\n```\r\n\r\nThe log itself is not more useful either :\r\n\r\n\r\n```\r\n# Sphinx version: 4.3.2\r\n# Python version: 3.9.9 (CPython)\r\n# Docutils version: 0.16 release\r\n# Jinja2 version: 2.11.3\r\n# Last messages:\r\n#   Lecture des sources... [ 43%] package.module1.submodule1\r\n#   Lecture des sources... [ 45%] package.submodules\r\n#   Lecture des sources... [ 47%] index\r\n#   Lecture des sources... [ 50%] modules\r\n#   Lecture des sources... [ 52%] tests\r\n#   Lecture des sources... [ 54%] tests.test_module1\r\n#   Lecture des sources... [ 56%] tests.test_module2\r\n#   Lecture des sources... [ 58%] tests.test_module2.submodule1\r\n#   Lecture des sources... [ 60%] tests.test_module2.submodule2\r\n# Loaded extensions:\r\n#   sphinx.ext.mathjax (4.3.2) from path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\mathjax.py\r\n#   sphinxcontrib.applehelp (1.0.2) from path\\to\\venv\\lib\\site-packages\\sphinxcontrib\\applehelp\\__init__.py\r\n#   sphinxcontrib.devhelp (1.0.2) from path\\to\\venv\\lib\\site-packages\\sphinxcontrib\\devhelp\\__init__.py\r\n#   sphinxcontrib.htmlhelp (2.0.0) from path\\to\\venv\\lib\\site-packages\\sphinxcontrib\\htmlhelp\\__init__.py\r\n#   sphinxcontrib.serializinghtml (1.1.5) from path\\to\\venv\\lib\\site-packages\\sphinxcontrib\\serializinghtml\\__init__.py\r\n#   sphinxcontrib.qthelp (1.0.3) from path\\to\\venv\\lib\\site-packages\\sphinxcontrib\\qthelp\\__init__.py\r\n#   alabaster (0.7.12) from path\\to\\venv\\lib\\site-packages\\alabaster\\__init__.py\r\n#   sphinx_rtd_theme (unknown version) from path\\to\\venv\\lib\\site-packages\\sphinx_rtd_theme\\__init__.py\r\n#   sphinx.ext.autodoc.preserve_defaults (1.0) from path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\preserve_defaults.py\r\n#   sphinx.ext.autodoc.type_comment (4.3.2) from path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\type_comment.py\r\n#   sphinx.ext.autodoc (4.3.2) from path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\__init__.py\r\n#   matplotlib.sphinxext.plot_directive (3.5.0) from path\\to\\venv\\lib\\site-packages\\matplotlib\\sphinxext\\plot_directive.py\r\nTraceback (most recent call last):\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\cmd\\build.py\", line 280, in build_main\r\n    app.build(args.force_all, filenames)\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\application.py\", line 344, in build\r\n    self.builder.build_update()\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\builders\\__init__.py\", line 294, in build_update\r\n    self.build(to_build,\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\builders\\__init__.py\", line 308, in build\r\n    updated_docnames = set(self.read())\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\builders\\__init__.py\", line 415, in read\r\n    self._read_serial(docnames)\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\builders\\__init__.py\", line 436, in _read_serial\r\n    self.read_doc(docname)\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\builders\\__init__.py\", line 476, in read_doc\r\n    doctree = read_doc(self.app, self.env, self.env.doc2path(docname))\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\io.py\", line 189, in read_doc\r\n    pub.publish()\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\core.py\", line 217, in publish\r\n    self.document = self.reader.read(self.source, self.parser,\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\io.py\", line 109, in read\r\n    self.parse()\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\readers\\__init__.py\", line 77, in parse\r\n    self.parser.parse(self.input, document)\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\parsers.py\", line 101, in parse\r\n    self.statemachine.run(inputlines, document, inliner=self.inliner)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 170, in run\r\n    results = StateMachineWS.run(self, input_lines, input_offset,\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\statemachine.py\", line 241, in run\r\n    context, next_state, result = self.check_line(\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\statemachine.py\", line 459, in check_line\r\n    return method(match, context, next_state)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 2769, in underline\r\n    self.section(title, source, style, lineno - 1, messages)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 327, in section\r\n    self.new_subsection(title, lineno, messages)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 393, in new_subsection\r\n    newabsoffset = self.nested_parse(\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 281, in nested_parse\r\n    state_machine.run(block, input_offset, memo=self.memo,\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 196, in run\r\n    results = StateMachineWS.run(self, input_lines, input_offset)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\statemachine.py\", line 241, in run\r\n    context, next_state, result = self.check_line(\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\statemachine.py\", line 459, in check_line\r\n    return method(match, context, next_state)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 2769, in underline\r\n    self.section(title, source, style, lineno - 1, messages)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 327, in section\r\n    self.new_subsection(title, lineno, messages)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 393, in new_subsection\r\n    newabsoffset = self.nested_parse(\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 281, in nested_parse\r\n    state_machine.run(block, input_offset, memo=self.memo,\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 196, in run\r\n    results = StateMachineWS.run(self, input_lines, input_offset)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\statemachine.py\", line 241, in run\r\n    context, next_state, result = self.check_line(\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\statemachine.py\", line 459, in check_line\r\n    return method(match, context, next_state)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 2342, in explicit_markup\r\n    nodelist, blank_finish = self.explicit_construct(match)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 2354, in explicit_construct\r\n    return method(self, expmatch)\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 2096, in directive\r\n    return self.run_directive(\r\n  File \"path\\to\\venv\\lib\\site-packages\\docutils\\parsers\\rst\\states.py\", line 2146, in run_directive\r\n    result = directive_instance.run()\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\directive.py\", line 162, in run\r\n    documenter.generate(more_content=self.content)\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\__init__.py\", line 984, in generate\r\n    self.document_members(all_members)\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\__init__.py\", line 842, in document_members\r\n    for (mname, member, isattr) in self.filter_members(members, want_all):\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\ext\\autodoc\\__init__.py\", line 723, in filter_members\r\n    doc = getdoc(member, self.get_attr, self.config.autodoc_inherit_docstrings,\r\n  File \"path\\to\\venv\\lib\\site-packages\\sphinx\\util\\inspect.py\", line 912, in getdoc\r\n    doc = inspect.getdoc(obj)\r\n  File \"path\\to\\python\\lib\\inspect.py\", line 614, in getdoc\r\n    doc = object.__doc__\r\nSystemError: null argument to internal routine\r\n\r\n```\r\n\r\nWhen we build the doc from the sources, we get this error.\r\nWhen we build it after generating `ui\\resources.py`, we get this error\r\nWhen we build it after generating `ui\\resources.py` and deleting the folder `ui\\resources`, we get this error\r\nWhen we build it after deleting the `ui\\resources` and the file `ui\\resources.py`, it works\r\n\r\n\n\n### How to Reproduce\n\nI am trying to create a minimal reproducable example but my attempts failed so far\r\n\r\nThe doc itself was built running the following powershell script\r\n\r\n```\r\ncd .\\docs\r\n\r\n# Remove previously generated auto-doc and plots\r\nRemove-Item .\\source\\* -Include *.rst -Exclude index.rst\r\n.\\make.bat clean\r\n\r\n# Generate source files for documentation from docstrings\r\nsphinx-apidoc -f -o source/ ../\r\n\r\n# build documentation\r\n.\\make.bat html\r\n```\r\n\n\n### Expected behavior\n\nThe main issue I had is not the error itself, as we are going to change how we package the pyside6 resources to the gui to fix it, but the fact that neither the error message nor the log pointed towards the issue\r\n\r\nTo find the culprit, I started to delete folders of my projet until I managed to build the doc and finally find the culprit.\n\n### Your project\n\nStill working on a minimal reproducible example\n\n### Screenshots\n\n_No response_\n\n### OS\n\nWindows 10\n\n### Python version\n\n3.9.9\n\n### Sphinx version\n\n4.3.2\n\n### Sphinx extensions\n\nsphinx_rtd_theme, sphinx.ext.autodoc, matplotlib.sphinxext.plot_directive'\n\n### Extra tools\n\nPyside6==6.2.2.1\n\n### Additional context\n\nThanks a lot for providing a great documentation tool !\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: Documenter.is_filtered_inherited_member\n"
    },
    {
      "similar_issue": {
        "issue_title": "[inheritance_diagram] Use class objects only from builtins while evaluating bases",
        "issue_body": "**Is your feature request related to a problem? Please describe.**\r\nIn `sphinx.ext.inheritance_diagram` extension, we iterate over all bases and verify if a class object belongs to one of the Python built-in classes. As of now, we simply check for its presence in all `builtins` objects. This may be simple but we are ignoring the fact that besides classes, `builtins` also contains functions and other built-in Python objects. \r\n\r\nThe above is a direct cause of the following bug:\r\n\r\n**Prerequisite code:**\r\n```\r\nimport builtins\r\nimport inspect\r\nclass classproperty(object):\r\n    def __init__(self, f):\r\n        self.f = f\r\n    def __get__(self, obj, owner):\r\n        return self.f(owner)\r\n\r\nclass NamedAction(object):\r\n    @classproperty\r\n    def name(self):\r\n        raise NotImplementedError()\r\n```\r\n\r\n**As of now:**\r\n```\r\npy_builtins = vars(builtins).values()    # As used in sphinx.ext.inheritance_diagram\r\ncls = NamedAction                        # defined above\r\ncls in py_builtins\r\n---------------------------------------------------------------------------\r\nNotImplementedError                       Traceback (most recent call last)\r\n<ipython-input-6-2e6b4af0d81c> in <module>\r\n----> 1 cls in py_builtins\r\n\r\n/usr/lib/python3.8/importlib/_bootstrap.py in __eq__(self, other)\r\n\r\n<ipython-input-3-a8bb3f065bd0> in __get__(self, obj, owner)\r\n      3         self.f = f\r\n      4     def __get__(self, obj, owner):\r\n----> 5         return self.f(owner)\r\n      6 \r\n\r\n<ipython-input-4-b0467820c849> in name(self)\r\n      2     @classproperty\r\n      3     def name(self):\r\n----> 4         raise NotImplementedError()\r\n      5 \r\n\r\nNotImplementedError: \r\n```\r\n\r\n**After the proposed fix:**\r\n```\r\npy_builtins = [obj for obj in vars(builtins).values()\r\n               if inspect.isclass(obj)]    # proposed fix\r\ncls = NamedAction                          # defined above\r\ncls in py_builtins\r\nFalse\r\n```\r\n\r\n**Describe the solution you'd like**\r\nThe solution here is pretty simple. Instead of relying on the entire `builtins`, let's separate out the classes via `inspect.isclass`\r\n\r\n**Describe alternatives you've considered**\r\nN/A\r\n\r\n**Additional context**\r\nN/A",
        "issue_id": 8146,
        "pr_number": 8147,
        "pr_title": "Fixes #8146: When identifying bases, only use classes from builtins",
        "pr_body": "Subject: When identifying bases, only use class objects from `builtins`\r\n\r\n### Feature or Bugfix\r\n- Feature\r\n- Minor refactoring\r\n\r\n### Purpose\r\nIn inheritance_diagram extension, while iterating over bases,\r\nwe verify if the base class is one of the Python built-in\r\nclass or not.\r\nAs of now, we simply check for its presence in all `builtins`\r\nobjects. Please note, `builtins` not only has built-in classes,\r\nbut also functions (like `open`) and other built-in objects.\r\n\r\nTo avoid any sort of future problem, it seems better to only\r\nuse classes (and of course exception classes).\r\n\r\n### Relates\r\n- Issue #8146 ",
        "issue_closed_at": "2020-09-20T09:02:12Z",
        "base_commit": "ae9f0dd29998a9985aea90777e92e03cf1c9d591"
      },
      "summary": "### Summary:\nThis issue pertains to the `sphinx.ext.inheritance_diagram` extension, where the handling of class objects from Python's built-ins is overly inclusive. The current implementation iterates through all base classes and checks if a class object is part of the built-in objects. However, this approach mistakenly includes non-class objects such as functions, leading to erroneous behavior when determining class membership.\n\n1. **Problem Description in General Terms:**\n   The issue arises from an incorrect method of verifying class objects against Python's built-in objects. The current mechanism involves checking presence within all built-in objects, which may include functions and other non-class entities, not solely classes.\n\n2. **Key Symptoms and Behaviors Observed:**\n   The primary symptom is a `NotImplementedError` triggered when a class, such as `NamedAction`, is wrongly assessed against built-in objects due to the presence of a non-class property (`name`) that raises this error.\n\n3. **Affected Components or Systems:**\n   The problem affects the `sphinx.ext.inheritance_diagram` extension, specifically within the `InheritanceGraph._class_info` function. This component is responsible for generating inheritance diagrams and is crucial for documentation purposes.\n\n4. **Potential Impact or Severity:**\n   This issue can cause incorrect inheritance diagrams, potentially misleading users of the documentation generated by Sphinx. Although not critical, it affects the accuracy and reliability of the documentation output.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   The fix involves refining the check to include only class objects by using `inspect.isclass` to filter built-in entities. By ensuring only class objects are considered, the proposed solution prevents erroneous checks against non-class entities, thereby avoiding the triggering of unintended exceptions like `NotImplementedError`.\n\nThis change corrects the logic in the `sphinx/ext/inheritance_diagram.py` file, particularly within the `InheritanceGraph._class_info` method, ensuring that only appropriate class objects are processed in the inheritance diagram 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: [inheritance_diagram] Use class objects only from builtins while evaluating bases\n\nBody:\n**Is your feature request related to a problem? Please describe.**\r\nIn `sphinx.ext.inheritance_diagram` extension, we iterate over all bases and verify if a class object belongs to one of the Python built-in classes. As of now, we simply check for its presence in all `builtins` objects. This may be simple but we are ignoring the fact that besides classes, `builtins` also contains functions and other built-in Python objects. \r\n\r\nThe above is a direct cause of the following bug:\r\n\r\n**Prerequisite code:**\r\n```\r\nimport builtins\r\nimport inspect\r\nclass classproperty(object):\r\n    def __init__(self, f):\r\n        self.f = f\r\n    def __get__(self, obj, owner):\r\n        return self.f(owner)\r\n\r\nclass NamedAction(object):\r\n    @classproperty\r\n    def name(self):\r\n        raise NotImplementedError()\r\n```\r\n\r\n**As of now:**\r\n```\r\npy_builtins = vars(builtins).values()    # As used in sphinx.ext.inheritance_diagram\r\ncls = NamedAction                        # defined above\r\ncls in py_builtins\r\n---------------------------------------------------------------------------\r\nNotImplementedError                       Traceback (most recent call last)\r\n<ipython-input-6-2e6b4af0d81c> in <module>\r\n----> 1 cls in py_builtins\r\n\r\n/usr/lib/python3.8/importlib/_bootstrap.py in __eq__(self, other)\r\n\r\n<ipython-input-3-a8bb3f065bd0> in __get__(self, obj, owner)\r\n      3         self.f = f\r\n      4     def __get__(self, obj, owner):\r\n----> 5         return self.f(owner)\r\n      6 \r\n\r\n<ipython-input-4-b0467820c849> in name(self)\r\n      2     @classproperty\r\n      3     def name(self):\r\n----> 4         raise NotImplementedError()\r\n      5 \r\n\r\nNotImplementedError: \r\n```\r\n\r\n**After the proposed fix:**\r\n```\r\npy_builtins = [obj for obj in vars(builtins).values()\r\n               if inspect.isclass(obj)]    # proposed fix\r\ncls = NamedAction                          # defined above\r\ncls in py_builtins\r\nFalse\r\n```\r\n\r\n**Describe the solution you'd like**\r\nThe solution here is pretty simple. Instead of relying on the entire `builtins`, let's separate out the classes via `inspect.isclass`\r\n\r\n**Describe alternatives you've considered**\r\nN/A\r\n\r\n**Additional context**\r\nN/A\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/inheritance_diagram.py\n  function: InheritanceGraph._class_info\n"
    },
    {
      "similar_issue": {
        "issue_title": "autodoc: empty __all__ attribute is ignored",
        "issue_body": "**Describe the bug**\r\nautodoc: empty `__all__` attribute is ignored\r\n\r\n**To Reproduce**\r\n```\r\n# example.py\r\n__all__ = []\r\n\r\n\r\ndef foo():\r\n    \"docstring\"\r\n\r\n\r\ndef bar():\r\n    \"docstring\"\r\n\r\n\r\ndef baz():\r\n    \"docstring\"\r\n```\r\n```\r\n# index.rst\r\n.. automodule:: example\r\n   :members:\r\n```\r\n\r\nAll foo, bar, and baz are shown.\r\n\r\n**Expected behavior**\r\nNo entries should be shown because `__all__` is empty.\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": 8594,
        "pr_number": 8595,
        "pr_title": "Fix #8594: autodoc: empty __all__ attribute is ignored",
        "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- An empty `__all__` should be represented as \"there is no public items\".\r\nBut autodoc considers all items on the module are public.  This changes\r\nthe behavior to correct one.\r\n- #8594 ",
        "issue_closed_at": "2020-12-28T07:47:35Z",
        "base_commit": "b19bce971e82f2497d67fdacdeca8db08ae0ba56"
      },
      "summary": "### Summary:\nThis issue pertains to the Sphinx documentation generator, specifically involving the `autodoc` feature. The problem arises when an empty `__all__` attribute within a Python module is ignored by `autodoc`, resulting in all module members being documented, contrary to expected behavior. In general terms, `__all__` is a list that explicitly declares public objects of a module, and when it is empty, no members should be documented.\n\nKey symptoms include:\n- Despite `__all__` being an empty list, all functions within the module (`foo`, `bar`, `baz`) were documented.\n- This behavior was reproducible by configuring `autodoc` to document module members via `.. automodule:: example :members:` directive in a reStructuredText file (`index.rst`).\n\nThe affected component is the `sphinx.ext.autodoc` extension within the Sphinx documentation tool, specifically the `ModuleDocumenter.get_module_members` function.\n\nThe potential impact of this issue is moderate as it could lead to incorrect or undesired documentation outputs, particularly for projects relying on `__all__` to control which module members are exposed in the generated documentation.\n\nRelevant technical details include the environment where the issue was observed: Mac OS, Python version 3.9.1, and the latest head of Sphinx version 3.x. The fix involved adjustments in the `sphinx/ext/autodoc/__init__.py` file to correct the behavior of how module members are determined when `__all__` is empty.",
      "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: empty __all__ attribute is ignored\n\nBody:\n**Describe the bug**\r\nautodoc: empty `__all__` attribute is ignored\r\n\r\n**To Reproduce**\r\n```\r\n# example.py\r\n__all__ = []\r\n\r\n\r\ndef foo():\r\n    \"docstring\"\r\n\r\n\r\ndef bar():\r\n    \"docstring\"\r\n\r\n\r\ndef baz():\r\n    \"docstring\"\r\n```\r\n```\r\n# index.rst\r\n.. automodule:: example\r\n   :members:\r\n```\r\n\r\nAll foo, bar, and baz are shown.\r\n\r\n**Expected behavior**\r\nNo entries should be shown because `__all__` is empty.\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: ModuleDocumenter.get_module_members\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:\nThis issue pertains to the Sphinx documentation tool, specifically its `automodule` directive, which is failing to document class attributes under certain conditions. The problem arises when a module (mod1) defines a class with an attribute and another module (mod2) imports this class. When attempting to document the second module using the `automodule` directive with the `:members:` option, the documentation generated does not include the doc-string for the class attribute.\n\nKey symptoms include the absence of documentation for class attributes when the class is imported into another module and documented from there. This behavior is observed when the class attribute is defined in an imported module and the importing module's `__all__` attribute includes the class, triggering the bug.\n\nThe issue affects the Sphinx autodoc extension, specifically the functionality responsible for generating documentation from Python modules and classes. The problem is rooted in the `class_documenter.generate()` function call, which incorrectly looks for the class definition in the importing module rather than the original module, leading to the omission of the attribute's documentation.\n\nThe potential impact includes incomplete or misleading documentation, which can result in confusion or errors for developers relying on accurate documentation for class attributes. This issue is significant for users who rely on Sphinx for automated documentation generation, particularly in projects with complex module structures.\n\nTechnical details involve the incorrect handling of module and real module names in the `class_documenter.generate()` function, with `check_module=False` and `real_modname=\"mod2\"` causing the source misidentification issue. The fix likely involves correcting this behavior to ensure that the original module is correctly identified as the source of the class definition and its attributes.\n\nChanges Summary:\nThe issue is addressed in the `sphinx/ext/autodoc.py` file, specifically in the `AttributeDocumenter.document_members` 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: 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": "Instance attributes are incorrectly added to Parent class with Sphinx 3.4.0",
        "issue_body": "**Describe the bug**\r\n\r\nTrying to build the docs of QCoDeS https://github.com/QCoDeS/Qcodes/pull/2549 with Sphinx 3.4.0 we are \r\nseeing a failure where an instance attribute on a class cannot be resolved. This attribute is not defined on that class \r\nbut only on a different subclass. e.g. `visabackend` is defined on `VisaInstrument` but not on the parent class of `VisaInstrument` called `Instrument` but Sphinx tries to get that attribute on a non related subclass of Instrument `ATS`\r\n\r\nThis happens because Sphinx modifies `__attributes__` in place. If a subclass does not define new class attributes it will reuse the `__attributes__` dict of the super class as seen in the following simple example:\r\n\r\n\r\n```python\r\nclass X:\r\n    a: int = 1 \r\n    def __init__(self):\r\n        self.b: int = 2\r\n            \r\nclass Y(X):\r\n    def __init__(self):\r\n        self.d: int = 4\r\n\r\nid(Y.__annotations__)\r\n3051582812872\r\n\r\nid(X.__annotations__)\r\n3051582812872\r\n\r\nid(Y.__annotations__) == id(X.__annotations__)\r\nTrue\r\n\r\n```\r\nAnd `AttributeDocumenter.update_annotations` modifies the annotation dictionary of the subclass in place causing the annotation dictionary of the super class to be modified with it. \r\n\r\nReplacing this with something that does \r\n\r\n```python\r\nannotations = deepcopy(inspect.getannotations(parent))\r\n\r\nfor cls in inspect.getmro(parent):\r\n   .... (existing code to update annotations)\r\n\r\nparent.__annotations__ = annotations\r\n```\r\nSeems to resolve the issue\r\n\r\n**To Reproduce**\r\n\r\n```\r\n\r\n$ sudo apt install pandoc\r\n$ git clone https://github.com/QCoDeS/Qcodes.git\r\n$ cd qcodes\r\n$ pip install -r requirements.txt -r docs_requirements.txt\r\n$ cd docs\r\n$ make htmlfast\r\n```\r\n\r\n**Expected behavior**\r\nOnly the relevant attributes are attempted to be imported and the docs build correctly.\r\n\r\n**Your project**\r\ngithub.com/qcodes/qcodes\r\n\r\n**Screenshots**\r\nIf applicable, add screenshots to help explain your problem.\r\n\r\n**Environment info**\r\n- OS: Linux Ubnutu 18.04 (Github actions )\r\n- Python version: 3.\r\n- Sphinx version: 3.4.0\r\n- Sphinx extensions:  e.g. ['nbsphinx', 'sphinx.ext.autodoc', 'sphinx.ext.autosummary',\r\n              'sphinx.ext.napoleon', 'sphinx-jsonschema', 'sphinx.ext.doctest',\r\n              'sphinx.ext.intersphinx', 'sphinx.ext.todo',\r\n              'sphinx.ext.coverage', 'sphinx.ext.mathjax',\r\n              'sphinx.ext.viewcode', 'sphinx.ext.githubpages',\r\n              'sphinx.ext.todo']\r\n",
        "issue_id": 8567,
        "pr_number": 8571,
        "pr_title": "Fix #8567: autodoc: Instance attributes are incorrectly added to Parent class",
        "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- The instance attributes on subclasses are shown on the document of\r\nparent class unexpectedly because of autodoc modifies `__annotations__`\r\nin place.  This fix creates a copy of `__annotations__` attribute and\r\nattach it to the subclass.\r\n- refs: #8567 ",
        "issue_closed_at": "2020-12-22T14:41:02Z",
        "base_commit": "31cad2ebe7a205154e1374bfa52338111e515719"
      },
      "summary": "### Summary:\n\nThis issue is related to a bug in Sphinx 3.4.0, a documentation generator for Python projects, which affects the way instance attributes are documented. The problem arises when Sphinx attempts to document instance attributes for a class hierarchy. Specifically, the bug causes attributes defined in a subclass to be incorrectly associated with its parent class. This is due to Sphinx modifying the `__annotations__` dictionary in place, leading to shared references between subclass and superclass annotations.\n\nKey symptoms include the failure to resolve instance attributes correctly during the documentation build process, which results in Sphinx trying to document attributes on unrelated subclasses. In the reported case, an attribute defined in a subclass (`VisaInstrument`) was incorrectly attempted to be resolved on a separate subclass (`ATS`) of the same parent class (`Instrument`).\n\nThe affected components primarily involve the Sphinx's attribute documentation mechanism, specifically the `AttributeDocumenter.update_annotations` function. This function erroneously updates the annotation dictionary of the superclass while modifying that of the subclass due to shared references.\n\nThe potential impact of this bug is significant for projects relying on Sphinx for documentation generation, as it can lead to incorrect or failed documentation builds. This affects the reliability and accuracy of the generated documentation, potentially causing confusion for users and developers.\n\nTo resolve the issue, a change was suggested to create a deep copy of the superclass's annotations before updating them, ensuring that modifications to subclass annotations do not affect those of the superclass. This approach prevents the incorrect sharing of annotation dictionaries between class hierarchies.\n\nThe changes were implemented in several functions within the `sphinx/ext/autodoc/__init__.py` module, including `NewTypeAttributeDocumenter.can_document_member`, `AttributeDocumenter.isinstanceattribute`, and `AttributeDocumenter.update_annotations`, to correct the behavior and ensure proper documentation of instance attributes.",
      "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: Instance attributes are incorrectly added to Parent class with Sphinx 3.4.0\n\nBody:\n**Describe the bug**\r\n\r\nTrying to build the docs of QCoDeS https://github.com/QCoDeS/Qcodes/pull/2549 with Sphinx 3.4.0 we are \r\nseeing a failure where an instance attribute on a class cannot be resolved. This attribute is not defined on that class \r\nbut only on a different subclass. e.g. `visabackend` is defined on `VisaInstrument` but not on the parent class of `VisaInstrument` called `Instrument` but Sphinx tries to get that attribute on a non related subclass of Instrument `ATS`\r\n\r\nThis happens because Sphinx modifies `__attributes__` in place. If a subclass does not define new class attributes it will reuse the `__attributes__` dict of the super class as seen in the following simple example:\r\n\r\n\r\n```python\r\nclass X:\r\n    a: int = 1 \r\n    def __init__(self):\r\n        self.b: int = 2\r\n            \r\nclass Y(X):\r\n    def __init__(self):\r\n        self.d: int = 4\r\n\r\nid(Y.__annotations__)\r\n3051582812872\r\n\r\nid(X.__annotations__)\r\n3051582812872\r\n\r\nid(Y.__annotations__) == id(X.__annotations__)\r\nTrue\r\n\r\n```\r\nAnd `AttributeDocumenter.update_annotations` modifies the annotation dictionary of the subclass in place causing the annotation dictionary of the super class to be modified with it. \r\n\r\nReplacing this with something that does \r\n\r\n```python\r\nannotations = deepcopy(inspect.getannotations(parent))\r\n\r\nfor cls in inspect.getmro(parent):\r\n   .... (existing code to update annotations)\r\n\r\nparent.__annotations__ = annotations\r\n```\r\nSeems to resolve the issue\r\n\r\n**To Reproduce**\r\n\r\n```\r\n\r\n$ sudo apt install pandoc\r\n$ git clone https://github.com/QCoDeS/Qcodes.git\r\n$ cd qcodes\r\n$ pip install -r requirements.txt -r docs_requirements.txt\r\n$ cd docs\r\n$ make htmlfast\r\n```\r\n\r\n**Expected behavior**\r\nOnly the relevant attributes are attempted to be imported and the docs build correctly.\r\n\r\n**Your project**\r\ngithub.com/qcodes/qcodes\r\n\r\n**Screenshots**\r\nIf applicable, add screenshots to help explain your problem.\r\n\r\n**Environment info**\r\n- OS: Linux Ubnutu 18.04 (Github actions )\r\n- Python version: 3.\r\n- Sphinx version: 3.4.0\r\n- Sphinx extensions:  e.g. ['nbsphinx', 'sphinx.ext.autodoc', 'sphinx.ext.autosummary',\r\n              'sphinx.ext.napoleon', 'sphinx-jsonschema', 'sphinx.ext.doctest',\r\n              'sphinx.ext.intersphinx', 'sphinx.ext.todo',\r\n              'sphinx.ext.coverage', 'sphinx.ext.mathjax',\r\n              'sphinx.ext.viewcode', 'sphinx.ext.githubpages',\r\n              'sphinx.ext.todo']\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: NewTypeAttributeDocumenter.can_document_member\n  function: AttributeDocumenter.isinstanceattribute\n  function: AttributeDocumenter.update_annotations\n"
    }
  ]
}