{
  "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",
  "similar_bug_items": [
    {
      "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_id": 8567,
      "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_closed_at": "2020-12-22T14:41:02Z",
      "base_commit": "31cad2ebe7a205154e1374bfa52338111e515719",
      "changes": [
        {
          "file": "sphinx/ext/autodoc/__init__.py",
          "type": "function",
          "name": "can_document_member",
          "class_name": "NewTypeAttributeDocumenter",
          "code": "def can_document_member(cls, member: Any, membername: str, isattr: bool, parent: Any\n                            ) -> bool:\n        return not isinstance(parent, ModuleDocumenter) and inspect.isNewType(member)"
        },
        {
          "file": "sphinx/ext/autodoc/__init__.py",
          "type": "function",
          "name": "isinstanceattribute",
          "class_name": "AttributeDocumenter",
          "code": "def isinstanceattribute(self) -> bool:\n        \"\"\"Check the subject is an instance attribute.\"\"\"\n        # uninitialized instance variable (PEP-526)\n        with mock(self.config.autodoc_mock_imports):\n            try:\n                ret = import_object(self.modname, self.objpath[:-1], 'class',\n                                    attrgetter=self.get_attr,\n                                    warningiserror=self.config.autodoc_warningiserror)\n                self.parent = ret[3]\n                annotations = get_type_hints(self.parent, None,\n                                             self.config.autodoc_type_aliases)\n                if self.objpath[-1] in annotations:\n                    self.object = UNINITIALIZED_ATTR\n                    return True\n            except ImportError:\n                pass\n\n        return False"
        },
        {
          "file": "sphinx/ext/autodoc/__init__.py",
          "type": "function",
          "name": "update_annotations",
          "class_name": "AttributeDocumenter",
          "code": "def update_annotations(self, parent: Any) -> None:\n        \"\"\"Update __annotations__ to support type_comment and so on.\"\"\"\n        try:\n            annotations = inspect.getannotations(parent)\n\n            for cls in inspect.getmro(parent):\n                try:\n                    module = safe_getattr(cls, '__module__')\n                    qualname = safe_getattr(cls, '__qualname__')\n\n                    analyzer = ModuleAnalyzer.for_module(module)\n                    analyzer.analyze()\n                    for (classname, attrname), annotation in analyzer.annotations.items():\n                        if classname == qualname and attrname not in annotations:\n                            annotations[attrname] = annotation  # type: ignore\n                except (AttributeError, PycodeError):\n                    pass\n        except AttributeError:\n            pass"
        }
      ]
    },
    {
      "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_id": 7821,
      "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_closed_at": "2020-06-14T02:48:20Z",
      "base_commit": "46f79c55e1242ae8bb49b14c0a9e226d119460e5",
      "changes": [
        {
          "file": "sphinx/ext/autodoc/__init__.py",
          "type": "function",
          "name": "annotate_to_first_argument",
          "class_name": "MethodDocumenter",
          "code": "def annotate_to_first_argument(self, func: Callable, typ: Type) -> None:\n        \"\"\"Annotate type hint to the first argument of function if needed.\"\"\"\n        try:\n            sig = inspect.signature(func)\n        except TypeError as exc:\n            logger.warning(__(\"Failed to get a method signature for %s: %s\"),\n                           self.fullname, exc)\n            return\n        except ValueError:\n            return\n        if len(sig.parameters) == 1:\n            return\n\n        params = list(sig.parameters.values())\n        if params[1].annotation is Parameter.empty:\n            params[1] = params[1].replace(annotation=typ)\n            func.__signature__ = sig.replace(parameters=params)"
        },
        {
          "file": "sphinx/ext/autodoc/__init__.py",
          "type": "function",
          "name": "annotate_to_first_argument",
          "class_name": "MethodDocumenter",
          "code": "def annotate_to_first_argument(self, func: Callable, typ: Type) -> None:\n        \"\"\"Annotate type hint to the first argument of function if needed.\"\"\"\n        try:\n            sig = inspect.signature(func)\n        except TypeError as exc:\n            logger.warning(__(\"Failed to get a method signature for %s: %s\"),\n                           self.fullname, exc)\n            return\n        except ValueError:\n            return\n        if len(sig.parameters) == 1:\n            return\n\n        params = list(sig.parameters.values())\n        if params[1].annotation is Parameter.empty:\n            params[1] = params[1].replace(annotation=typ)\n            func.__signature__ = sig.replace(parameters=params)"
        }
      ]
    },
    {
      "pr_number": 6592,
      "pr_title": "Fix #6589: autodoc: Formatting issues with autodoc_typehints='none'",
      "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- refs: #6589 ",
      "issue_id": 6589,
      "issue_title": "Formatting issues with autodoc_typehints='none'",
      "issue_body": "**Describe the bug**\r\n\r\nWhen using `autodoc_typehints='none'`, I see two issues currently:\r\n\r\n1. When an annotated parameter has a default value, spaces are inserted around `=` where they are not for unannotated parameters. Consider:\r\n\r\n   ```python\r\n   def foo(x=True, y: bool = True, z = True):\r\n       return x and y and z\r\n   ```\r\n\r\n   The result looks like:\r\n\r\n   **foo**(*x=True, y = True, z=True*)\r\n\r\n2. Return types are not removed. Consider:\r\n\r\n   ```python\r\n   def bar(x: int) -> int:\r\n       return x * 2\r\n   ```\r\n\r\n   The result looks like:\r\n\r\n   **bar**(*x*) -> int\r\n\r\n**To Reproduce**\r\nSteps to reproduce the behavior:\r\n\r\nUse the above examples with the `autodoc_typehints='none'` option, or with the attached project (see below).\r\n\r\n**Expected behavior**\r\n\r\nI expect the annotated and unannotated parameters to be rendered similarly and for return type annotations to be removed as well, as if they were not there originally.\r\n\r\n**Your project**\r\n\r\nSee attached [foobar.zip](https://github.com/sphinx-doc/sphinx/files/3406054/foobar.zip)\r\n\r\n**Environment info**\r\n- OS: [Pop!_OS 18.10]\r\n- Python version: 3.6.8\r\n- Sphinx version: 2.1.2\r\n- Sphinx extensions:  [sphinx.ext.autodoc]\r\n\r\n**Additional context**\r\n\r\n- #6361 \r\n- #5868 \r\n- https://github.com/agronholm/sphinx-autodoc-typehints/pull/78\r\n\r\n",
      "issue_closed_at": "2019-08-02T13:37:16Z",
      "base_commit": "4732ec5edf9e53e2fa78cd5e1ff6bee92f1b27b7",
      "changes": [
        {
          "file": "sphinx/util/inspect.py",
          "type": "function",
          "name": "format_args",
          "class_name": "Signature",
          "code": "def format_args(self, show_annotation: bool = True) -> str:\n        args = []\n        last_kind = None\n        for i, param in enumerate(self.parameters.values()):\n            # skip first argument if subject is bound method\n            if self.skip_first_argument and i == 0:\n                continue\n\n            arg = StringIO()\n\n            # insert '*' between POSITIONAL args and KEYWORD_ONLY args::\n            #     func(a, b, *, c, d):\n            if param.kind == param.KEYWORD_ONLY and last_kind in (param.POSITIONAL_OR_KEYWORD,\n                                                                  param.POSITIONAL_ONLY,\n                                                                  None):\n                args.append('*')\n\n            if param.kind in (param.POSITIONAL_ONLY,\n                              param.POSITIONAL_OR_KEYWORD,\n                              param.KEYWORD_ONLY):\n                arg.write(param.name)\n                if show_annotation and param.annotation is not param.empty:\n                    if isinstance(param.annotation, str) and param.name in self.annotations:\n                        arg.write(': ')\n                        arg.write(self.format_annotation(self.annotations[param.name]))\n                    else:\n                        arg.write(': ')\n                        arg.write(self.format_annotation(param.annotation))\n                if param.default is not param.empty:\n                    if param.annotation is param.empty:\n                        arg.write('=')\n                        arg.write(object_description(param.default))\n                    else:\n                        arg.write(' = ')\n                        arg.write(object_description(param.default))\n            elif param.kind == param.VAR_POSITIONAL:\n                arg.write('*')\n                arg.write(param.name)\n            elif param.kind == param.VAR_KEYWORD:\n                arg.write('**')\n                arg.write(param.name)\n\n            args.append(arg.getvalue())\n            last_kind = param.kind\n\n        if self.return_annotation is inspect.Parameter.empty:\n            return '(%s)' % ', '.join(args)\n        else:\n            if 'return' in self.annotations:\n                annotation = self.format_annotation(self.annotations['return'])\n            else:\n                annotation = self.format_annotation(self.return_annotation)\n\n            return '(%s) -> %s' % (', '.join(args), annotation)"
        },
        {
          "file": "sphinx/util/inspect.py",
          "type": "function",
          "name": "format_args",
          "class_name": "Signature",
          "code": "def format_args(self, show_annotation: bool = True) -> str:\n        args = []\n        last_kind = None\n        for i, param in enumerate(self.parameters.values()):\n            # skip first argument if subject is bound method\n            if self.skip_first_argument and i == 0:\n                continue\n\n            arg = StringIO()\n\n            # insert '*' between POSITIONAL args and KEYWORD_ONLY args::\n            #     func(a, b, *, c, d):\n            if param.kind == param.KEYWORD_ONLY and last_kind in (param.POSITIONAL_OR_KEYWORD,\n                                                                  param.POSITIONAL_ONLY,\n                                                                  None):\n                args.append('*')\n\n            if param.kind in (param.POSITIONAL_ONLY,\n                              param.POSITIONAL_OR_KEYWORD,\n                              param.KEYWORD_ONLY):\n                arg.write(param.name)\n                if show_annotation and param.annotation is not param.empty:\n                    if isinstance(param.annotation, str) and param.name in self.annotations:\n                        arg.write(': ')\n                        arg.write(self.format_annotation(self.annotations[param.name]))\n                    else:\n                        arg.write(': ')\n                        arg.write(self.format_annotation(param.annotation))\n                if param.default is not param.empty:\n                    if param.annotation is param.empty:\n                        arg.write('=')\n                        arg.write(object_description(param.default))\n                    else:\n                        arg.write(' = ')\n                        arg.write(object_description(param.default))\n            elif param.kind == param.VAR_POSITIONAL:\n                arg.write('*')\n                arg.write(param.name)\n            elif param.kind == param.VAR_KEYWORD:\n                arg.write('**')\n                arg.write(param.name)\n\n            args.append(arg.getvalue())\n            last_kind = param.kind\n\n        if self.return_annotation is inspect.Parameter.empty:\n            return '(%s)' % ', '.join(args)\n        else:\n            if 'return' in self.annotations:\n                annotation = self.format_annotation(self.annotations['return'])\n            else:\n                annotation = self.format_annotation(self.return_annotation)\n\n            return '(%s) -> %s' % (', '.join(args), annotation)"
        }
      ]
    },
    {
      "pr_number": 5470,
      "pr_title": "Fixes #5426: [Napoleon] Better handling of inline attributes",
      "pr_body": "Fixes #5426: [Napoleon] Better handling of inline attributes\r\n\r\n### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- Better handling of inline attributes by Napoleon to support both Napoleon style attribute docstrings and the specifically formatted docstring for class data members.\r\n",
      "issue_id": 5426,
      "issue_title": "TypeError in docutils/writers/_html_base.py for autodoc'd class data member",
      "issue_body": "This bug does not occur with previous versions of Sphinx.\r\n\r\nA class's data member must have a specifically formatted docstring.\r\n\r\nThe first part of the docstring (the main text) must match the regular expression /:\\s*$/ (ends with a colon). After the colon, any amount of whitespace may be present. The text thereafter is an enumerated list (both - and * work) of any number of items. The first list item matches the expression /:/ (contains a colon).\r\n\r\n# Environment\r\n\r\n- OS: OSX 10.13.6\r\n- Python version: 3.7 (installed via homebrew). Also happens in 3.6.4.\r\n- Sphinx version: 1.8.0\r\n\r\n# Test Case\r\n\r\nRun autodoc on the following and generate HTML:\r\n\r\n```python\r\nclass SomeClass:\r\n  some_data = 0\r\n  \"\"\"data member description:\r\n\r\n  - a: b\r\n  \"\"\"\r\n```\r\n\r\n# Actual Result\r\n\r\nSphinx crashes with the following output:\r\n\r\n```writing output...                                                                                                                                          \r\nException occurred:\r\n  File \".../site-packages/docutils/writers/_html_base.py\", line 399, in set_class_on_child\r\n    child['classes'].append(class_)\r\nTypeError: string indices must be integers\r\n```\r\n\r\n# Error logs / results\r\n\r\n```\r\n# Sphinx version: 1.8.0\r\n# Python version: 3.7.0 (CPython)\r\n# Docutils version: 0.14 \r\n# Jinja2 version: 2.10\r\n# Last messages:\r\n#   writing output... [ 59%] someclass\r\n#   \r\n# Loaded extensions:\r\n#   sphinx.ext.mathjax (1.8.0) from /.venv/lib/python3.7/site-packages/sphinx/ext/mathjax.py\r\n#   alabaster (0.7.11) from /.venv/lib/python3.7/site-packages/alabaster/__init__.py\r\n#   sphinx.ext.autodoc (1.8.0) from /.venv/lib/python3.7/site-packages/sphinx/ext/autodoc/__init__.py\r\n#   sphinx.ext.napoleon (1.8.0) from /.venv/lib/python3.7/site-packages/sphinx/ext/napoleon/__init__.py\r\nTraceback (most recent call last):\r\n  File \"/.venv/lib/python3.7/site-packages/sphinx/cmd/build.py\", line 304, in build_main\r\n    app.build(args.force_all, filenames)\r\n  File \"/.venv/lib/python3.7/site-packages/sphinx/application.py\", line 341, in build\r\n    self.builder.build_update()\r\n  File \"/.venv/lib/python3.7/site-packages/sphinx/builders/__init__.py\", line 347, in build_update\r\n    len(to_build))\r\n  File \"/.venv/lib/python3.7/site-packages/sphinx/builders/__init__.py\", line 412, in build\r\n    self.write(docnames, list(updated_docnames), method)\r\n  File \"/.venv/lib/python3.7/site-packages/sphinx/builders/__init__.py\", line 593, in write\r\n    self._write_serial(sorted(docnames))\r\n  File \"/.venv/lib/python3.7/site-packages/sphinx/builders/__init__.py\", line 604, in _write_serial\r\n    self.write_doc(docname, doctree)\r\n  File \"/.venv/lib/python3.7/site-packages/sphinx/builders/html.py\", line 730, in write_doc\r\n    self.docwriter.write(doctree, destination)\r\n  File \"/.venv/lib/python3.7/site-packages/docutils/writers/__init__.py\", line 80, in write\r\n    self.translate()\r\n  File \"/.venv/lib/python3.7/site-packages/sphinx/writers/html.py\", line 58, in translate\r\n    self.document.walkabout(visitor)\r\n  File \"/.venv/lib/python3.7/site-packages/docutils/nodes.py\", line 174, in walkabout\r\n    if child.walkabout(visitor):\r\n  File \"/.venv/lib/python3.7/site-packages/docutils/nodes.py\", line 174, in walkabout\r\n    if child.walkabout(visitor):\r\n  File \"/.venv/lib/python3.7/site-packages/docutils/nodes.py\", line 174, in walkabout\r\n    if child.walkabout(visitor):\r\n  [Previous line repeated 4 more times]\r\n  File \"/.venv/lib/python3.7/site-packages/docutils/nodes.py\", line 166, in walkabout\r\n    visitor.dispatch_visit(self)\r\n  File \"/.venv/lib/python3.7/site-packages/docutils/nodes.py\", line 1882, in dispatch_visit\r\n    return method(node)\r\n  File \"/.venv/lib/python3.7/site-packages/docutils/writers/html4css1/__init__.py\", line 402, in visit_field_body\r\n    self.set_class_on_child(node, 'first', 0)\r\n  File \"/.venv/lib/python3.7/site-packages/docutils/writers/_html_base.py\", line 399, in set_class_on_child\r\n    child['classes'].append(class_)\r\nTypeError: string indices must be integers\r\n```\r\n\r\n",
      "issue_closed_at": "2018-09-23T13:26:17Z",
      "base_commit": "37d58ab9d5b27403226c7e6ddc1cc48b905db297",
      "changes": [
        {
          "file": "sphinx/ext/napoleon/__init__.py",
          "type": "line",
          "name": "line 9",
          "code": "    :license: BSD, see LICENSE for details.\n\"\"\"\n\nimport sphinx\nfrom sphinx.application import Sphinx\nfrom sphinx.ext.napoleon.docstring import GoogleDocstring, NumpyDocstring\n"
        },
        {
          "file": "sphinx/ext/napoleon/__init__.py",
          "type": "function",
          "name": "setup",
          "class_name": null,
          "code": "def setup(app):\n    # type: (Sphinx) -> Dict[unicode, Any]\n    \"\"\"Sphinx extension setup function.\n\n    When the extension is loaded, Sphinx imports this module and executes\n    the ``setup()`` function, which in turn notifies Sphinx of everything\n    the extension offers.\n\n    Parameters\n    ----------\n    app : sphinx.application.Sphinx\n        Application object representing the Sphinx process\n\n    See Also\n    --------\n    `The Sphinx documentation on Extensions\n    <http://sphinx-doc.org/extensions.html>`_\n\n    `The Extension Tutorial <http://sphinx-doc.org/extdev/tutorial.html>`_\n\n    `The Extension API <http://sphinx-doc.org/extdev/appapi.html>`_\n\n    \"\"\"\n    if not isinstance(app, Sphinx):\n        return  # probably called by tests\n\n    _patch_python_domain()\n\n    app.setup_extension('sphinx.ext.autodoc')\n    app.connect('autodoc-process-docstring', _process_docstring)\n    app.connect('autodoc-skip-member', _skip_member)\n\n    for name, (default, rebuild) in Config._config_values.items():\n        app.add_config_value(name, default, rebuild)\n    return {'version': sphinx.__display_version__, 'parallel_read_safe': True}"
        },
        {
          "file": "sphinx/ext/napoleon/__init__.py",
          "type": "function",
          "name": "setup",
          "class_name": null,
          "code": "def setup(app):\n    # type: (Sphinx) -> Dict[unicode, Any]\n    \"\"\"Sphinx extension setup function.\n\n    When the extension is loaded, Sphinx imports this module and executes\n    the ``setup()`` function, which in turn notifies Sphinx of everything\n    the extension offers.\n\n    Parameters\n    ----------\n    app : sphinx.application.Sphinx\n        Application object representing the Sphinx process\n\n    See Also\n    --------\n    `The Sphinx documentation on Extensions\n    <http://sphinx-doc.org/extensions.html>`_\n\n    `The Extension Tutorial <http://sphinx-doc.org/extdev/tutorial.html>`_\n\n    `The Extension API <http://sphinx-doc.org/extdev/appapi.html>`_\n\n    \"\"\"\n    if not isinstance(app, Sphinx):\n        return  # probably called by tests\n\n    _patch_python_domain()\n\n    app.setup_extension('sphinx.ext.autodoc')\n    app.connect('autodoc-process-docstring', _process_docstring)\n    app.connect('autodoc-skip-member', _skip_member)\n\n    for name, (default, rebuild) in Config._config_values.items():\n        app.add_config_value(name, default, rebuild)\n    return {'version': sphinx.__display_version__, 'parallel_read_safe': True}"
        },
        {
          "file": "sphinx/ext/napoleon/docstring.py",
          "type": "function",
          "name": "_consume_inline_attribute",
          "class_name": "GoogleDocstring",
          "code": "def _consume_inline_attribute(self):\n        # type: () -> Tuple[unicode, List[unicode]]\n        line = next(self._line_iter)\n        _type, colon, _desc = self._partition_field_on_colon(line)\n        if not colon:\n            _type, _desc = _desc, _type\n        _descs = [_desc] + self._dedent(self._consume_to_end())\n        _descs = self.__class__(_descs, self._config).lines()\n        return _type, _descs"
        }
      ]
    },
    {
      "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"
        }
      ]
    }
  ]
}