{
    "Selected_candidate": {
        "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_id": 2298,
        "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_closed_at": "2017-11-11T16:53:43Z",
        "base_commit": "bdc230b1ccc189989789f82a55023f369410309d",
        "changes": [
            {
                "file": "sphinx/ext/autodoc.py",
                "type": "function",
                "name": "document_members",
                "class_name": "AttributeDocumenter",
                "code": "def document_members(self, all_members=False):\n        pass"
            }
        ]
    },
    "Justification": "Candidate D is the most helpful as it deals directly with issues regarding class attributes in the context of Sphinx's autodoc. The underlying mechanism causing attributes to be undocumented is relevant to the CURRENT bug, which seeks to control which inherited members are documented. Understanding and applying the fix from Candidate D can provide critical insights into managing document generation when dealing with complex inheritance hierarchies."
}