{
  "Selected_candidate": {
    "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_id": 2044,
    "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_closed_at": "2020-04-23T12:57:37Z",
    "base_commit": "12cb90c3fa5451e2c99100d8ce1d4d0a8bb7f527",
    "changes": [
      {
        "file": "sphinx/ext/autodoc/__init__.py",
        "type": "function",
        "name": "identity",
        "class_name": null,
        "code": "def identity(x: Any) -> Any:\n    return x"
      },
      {
        "file": "sphinx/ext/autodoc/__init__.py",
        "type": "function",
        "name": "add_directive_header",
        "class_name": "PropertyDocumenter",
        "code": "def add_directive_header(self, sig: str) -> None:\n        super().add_directive_header(sig)\n        sourcename = self.get_sourcename()\n        if inspect.isabstractmethod(self.object):\n            self.add_line('   :abstractmethod:', sourcename)\n        self.add_line('   :property:', sourcename)"
      },
      {
        "file": "sphinx/ext/autodoc/__init__.py",
        "type": "function",
        "name": "import_object",
        "class_name": "SlotsAttributeDocumenter",
        "code": "def import_object(self) -> Any:\n        \"\"\"Never import anything.\"\"\"\n        # disguise as an attribute\n        self.objtype = 'attribute'\n        self._datadescriptor = True\n\n        with mock(self.env.config.autodoc_mock_imports):\n            try:\n                ret = import_object(self.modname, self.objpath[:-1], 'class',\n                                    attrgetter=self.get_attr,\n                                    warningiserror=self.env.config.autodoc_warningiserror)\n                self.module, _, _, self.parent = ret\n                return True\n            except ImportError as exc:\n                logger.warning(exc.args[0], type='autodoc', subtype='import_object')\n                self.env.note_reread()\n                return False"
      },
      {
        "file": "sphinx/ext/autodoc/__init__.py",
        "type": "function",
        "name": "add_directive_header",
        "class_name": "PropertyDocumenter",
        "code": "def add_directive_header(self, sig: str) -> None:\n        super().add_directive_header(sig)\n        sourcename = self.get_sourcename()\n        if inspect.isabstractmethod(self.object):\n            self.add_line('   :abstractmethod:', sourcename)\n        self.add_line('   :property:', sourcename)"
      },
      {
        "file": "sphinx/ext/autodoc/__init__.py",
        "type": "function",
        "name": "import_object",
        "class_name": "SlotsAttributeDocumenter",
        "code": "def import_object(self) -> Any:\n        \"\"\"Never import anything.\"\"\"\n        # disguise as an attribute\n        self.objtype = 'attribute'\n        self._datadescriptor = True\n\n        with mock(self.env.config.autodoc_mock_imports):\n            try:\n                ret = import_object(self.modname, self.objpath[:-1], 'class',\n                                    attrgetter=self.get_attr,\n                                    warningiserror=self.env.config.autodoc_warningiserror)\n                self.module, _, _, self.parent = ret\n                return True\n            except ImportError as exc:\n                logger.warning(exc.args[0], type='autodoc', subtype='import_object')\n                self.env.note_reread()\n                return False"
      }
    ]
  },
  "Justification": "Candidate E is the most relevant as it deals specifically with the Sphinx `autodoc` extension, which is central to the CURRENT bug report involving `viewcode` and the creation of pages for epub. Both issues deal with how Sphinx generates documentation and handles attributes, including the suppression of unnecessary information in the generated docs. The insights into managing instance attributes and docstring formatting could provide useful guidance on resolving the unintended page generation problem in the CURRENT bug report, especially regarding configuration options for the Sphinx extensions.",
  "instance_id": "sphinx-doc__sphinx-8721",
  "repo": "sphinx-doc/sphinx",
  "created_at": "2021-01-21T15:36:24Z",
  "problem_statement": "viewcode creates pages for epub even if `viewcode_enable_epub=False` on `make html epub`\n**Describe the bug**\r\nviewcode creates pages for epub even if `viewcode_enable_epub=False` on `make html epub`\r\n\r\n**To Reproduce**\r\n```\r\n$ make html epub\r\n```\r\n\r\n**Expected behavior**\r\nmodule pages should not be created for epub by default.\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.viewcode\r\n- Extra tools: No\r\n\r\n**Additional context**\r\nNo\r\n\n",
  "patch": "diff --git a/sphinx/ext/viewcode.py b/sphinx/ext/viewcode.py\n--- a/sphinx/ext/viewcode.py\n+++ b/sphinx/ext/viewcode.py\n@@ -182,6 +182,10 @@ def collect_pages(app: Sphinx) -> Generator[Tuple[str, Dict[str, Any], str], Non\n     env = app.builder.env\n     if not hasattr(env, '_viewcode_modules'):\n         return\n+    if app.builder.name == \"singlehtml\":\n+        return\n+    if app.builder.name.startswith(\"epub\") and not env.config.viewcode_enable_epub:\n+        return\n     highlighter = app.builder.highlighter  # type: ignore\n     urito = app.builder.get_relative_uri\n \n"
}