{
  "Selected_candidate": {
    "pr_number": 4614,
    "pr_title": "Fix false positive useless type annotation for pep484 typing",
    "pr_body": "## Description\r\n\r\nFix false positive ``useless-type-doc`` on ignored argument using ``pylint.extensions.docparams``\r\n  when a function was typed using pep484 but not inside the docstring.\r\n\r\n\r\n## Type of Changes\r\n\r\n<!-- Leave the corresponding lines for the applicable type of change: -->\r\n\r\n|     | Type                   |\r\n| --- | ---------------------- |\r\n| ✓   | :bug: Bug fix          |\r\n\r\n## Related Issue\r\n\r\n  Closes #4117\r\n  Closes #4593",
    "issue_id": 4593,
    "issue_title": "useless-type-doc issued for undocumented parameters that have PEP484 type annotations",
    "issue_body": "<!--\r\n  Hi there! Thank you for discovering and submitting an issue.\r\n\r\n  Before you submit this, make sure that the issue doesn't already exist\r\n  or if it is not closed.\r\n\r\n  Is your issue fixed on the preview release?:\r\n    pip install pylint astroid --pre -U\r\n-->\r\n\r\nThis likely relates to (and solves) issue #4117.\r\n\r\n### Steps to reproduce\r\n\r\nCall pylint with the docparams extension enabled on the following code:\r\n\r\n```python\r\n'''demonstrate FP with useless-type-doc'''\r\n\r\ndef function(public_param: int, _some_private_param: bool = False) -> None:\r\n    '''does things\r\n\r\n    Args:\r\n        public_param: an ordinary parameter\r\n    '''\r\n    for _ in range(public_param):\r\n        ...\r\n    if _some_private_param:\r\n        ...\r\n    else:\r\n        ...\r\n```\r\n\r\n### Current behavior\r\n\r\n```\r\n$ python3 -m pylint --load-plugins=pylint.extensions.docparams --rcfile=/dev/null bug.py\r\n************* Module bug\r\nbug.py:4:0: W9020: \"_some_private_param\" useless ignored parameter type documentation (useless-type-doc)\r\n\r\n------------------------------------------------------------------\r\nYour code has been rated at 8.33/10 (previous run: 5.00/10, +3.33)\r\n```\r\n\r\n### Expected behavior\r\n\r\nPylint should issue no errors.\r\n\r\nIt would be reasonable for pylint to issue this error if the type information appeared in the docstring, however, pylint is actually responding to the type annotation (as in PEP484). The docparams module should only issue errors in response to docstrings (or lack thereof), and not PEP484 annotations.\r\n\r\n### pylint --version output\r\n\r\nResult of `pylint --version` output:\r\n\r\n```\r\npylint 2.8.1\r\nastroid 2.5.6\r\nPython 3.8.3 (default, Jul  6 2020, 09:12:34)\r\n[Clang 10.0.1 (clang-1001.0.46.4)]\r\n```\r\n",
    "issue_closed_at": "2021-06-25T12:34:49Z",
    "base_commit": "bebdf9b3aee66c5d8937ed2a8993db398995c6b3",
    "changes": [
      {
        "file": "pylint/extensions/_check_docs_utils.py",
        "type": "function",
        "name": "__init__",
        "class_name": "Docstring",
        "code": "def __init__(self, doc):\n        doc = doc or \"\"\n        self.doc = doc.expandtabs()"
      },
      {
        "file": "pylint/extensions/docparams.py",
        "type": "line",
        "name": "line 23",
        "code": "\"\"\"Pylint plugin for checking in Sphinx, Google, or Numpy style docstrings\n\"\"\"\nimport re\n\nimport astroid\n\nfrom pylint.checkers import BaseChecker\nfrom pylint.checkers import utils as checker_utils\nfrom pylint.extensions import _check_docs_utils as utils\nfrom pylint.interfaces import IAstroidChecker\nfrom pylint.utils import get_global_option\n"
      },
      {
        "file": "pylint/extensions/docparams.py",
        "type": "function",
        "name": "_compare_ignored_args",
        "class_name": "DocstringParameterChecker",
        "code": "def _compare_ignored_args(\n        self,\n        found_argument_names,\n        message_id,\n        ignored_argument_names,\n        warning_node,\n    ):\n        \"\"\"Compare the found argument names with the ignored ones and\n        generate a message if there are ignored arguments found.\n\n        :param found_argument_names: argument names found in the docstring\n        :type found_argument_names: set\n\n        :param message_id: pylint message id\n        :type message_id: str\n\n        :param ignored_argument_names: Expected argument names\n        :type ignored_argument_names: set\n\n        :param warning_node: The node to be analyzed\n        :type warning_node: :class:`astroid.scoped_nodes.Node`\n        \"\"\"\n        existing_ignored_argument_names = ignored_argument_names & found_argument_names\n\n        if existing_ignored_argument_names:\n            self.add_message(\n                message_id,\n                args=(\", \".join(sorted(existing_ignored_argument_names)),),\n                node=warning_node,\n            )"
      }
    ]
  },
  "Justification": "Candidate A is the most helpful because it discusses the behavior of Pylint when it doesn't properly issue warnings for parameters with type annotations, which is somewhat related to the use of notes in the CURRENT bug report. Both reports deal with aspects of how Pylint interprets and responds to specific syntax cases. The underlying issue of whether Pylint correctly identifies problematic code resonates with the issue of not catching notes that are entirely punctuation. The modern version of Pylint that the candidate report is based on could provide insights into relevant fixes that may apply to the CURRENT bug as well.",
  "instance_id": "pylint-dev__pylint-5859",
  "repo": "pylint-dev/pylint",
  "created_at": "2022-03-04T00:01:54Z",
  "problem_statement": "\"--notes\" option ignores note tags that are entirely punctuation\n### Bug description\n\nIf a note tag specified with the `--notes` option is entirely punctuation, pylint won't report a fixme warning (W0511).\r\n\r\n```python\r\n# YES: yes\r\n# ???: no\r\n```\r\n\r\n`pylint test.py --notes=\"YES,???\"` will return a fixme warning (W0511) for the first line, but not the second.\n\n### Configuration\n\n```ini\nDefault\n```\n\n\n### Command used\n\n```shell\npylint test.py --notes=\"YES,???\"\n```\n\n\n### Pylint output\n\n```shell\n************* Module test\r\ntest.py:1:1: W0511: YES: yes (fixme)\n```\n\n\n### Expected behavior\n\n```\r\n************* Module test\r\ntest.py:1:1: W0511: YES: yes (fixme)\r\ntest.py:2:1: W0511: ???: no (fixme)\r\n```\n\n### Pylint version\n\n```shell\npylint 2.12.2\r\nastroid 2.9.0\r\nPython 3.10.2 (main, Feb  2 2022, 05:51:25) [Clang 13.0.0 (clang-1300.0.29.3)]\n```\n\n\n### OS / Environment\n\nmacOS 11.6.1\n\n### Additional dependencies\n\n_No response_\n",
  "patch": "diff --git a/pylint/checkers/misc.py b/pylint/checkers/misc.py\n--- a/pylint/checkers/misc.py\n+++ b/pylint/checkers/misc.py\n@@ -121,9 +121,9 @@ def open(self):\n \n         notes = \"|\".join(re.escape(note) for note in self.config.notes)\n         if self.config.notes_rgx:\n-            regex_string = rf\"#\\s*({notes}|{self.config.notes_rgx})\\b\"\n+            regex_string = rf\"#\\s*({notes}|{self.config.notes_rgx})(?=(:|\\s|\\Z))\"\n         else:\n-            regex_string = rf\"#\\s*({notes})\\b\"\n+            regex_string = rf\"#\\s*({notes})(?=(:|\\s|\\Z))\"\n \n         self._fixme_pattern = re.compile(regex_string, re.I)\n \n"
}