{
  "original_problem": {
    "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"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_4593",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves type annotations and docstring conflicts, which is unrelated to handling punctuation in note tags."
      },
      {
        "idx": 2,
        "id": "similar_1342",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The problem is about error code differentiation in docstring checks, not relevant to regex handling of punctuation."
      },
      {
        "idx": 3,
        "id": "similar_5261",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "This issue deals with handling private variables and AST traversal, unrelated to regex or punctuation handling."
      },
      {
        "idx": 4,
        "id": "similar_4580",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about TOML configuration parsing errors, not related to regex or punctuation handling in note tags."
      },
      {
        "idx": 5,
        "id": "similar_3064",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "This issue involves suppression of cyclic-import warnings, which does not relate to regex handling of punctuation."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "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_id": 4593,
        "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_closed_at": "2021-06-25T12:34:49Z",
        "base_commit": "bebdf9b3aee66c5d8937ed2a8993db398995c6b3"
      },
      "summary": "### Summary:\n\nThis issue involves a problem with the Pylint tool, specifically when using the `docparams` extension. The reported behavior occurs when Pylint incorrectly flags type annotations as \"useless-type-doc\" errors in situations where function parameters are annotated according to PEP484, but not documented in the function's docstring.\n\n1. **Problem Description in General Terms**:\n   The problem arises due to a conflict between PEP484 type annotations and Pylint's docparams extension. Pylint generates warnings for parameters that have type annotations but are not documented in docstrings. This behavior is incorrect when the type information is already provided in the annotations.\n\n2. **Key Symptoms and Behaviors Observed**:\n   Users observe that Pylint issues a \"useless-type-doc\" warning for parameters with type annotations, even though these should not require additional documentation in docstrings. This results in an unexpected error message when running Pylint checks on Python code.\n\n3. **Affected Components or Systems**:\n   The issue specifically affects the Pylint tool, particularly the `docparams` extension, which is responsible for checking parameter documentation within code comments and annotations.\n\n4. **Potential Impact or Severity**:\n   The impact of this issue may be considered moderate, as it leads to false-positive warnings during code linting, potentially causing confusion and unnecessary effort for developers to address non-existent issues.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**:\n   PEP484 introduces a standard for type annotations in Python, allowing developers to specify types directly in the function signature. The `docparams` module should ideally only validate parameter documentation based on docstrings without conflicting with these annotations. The fix involved adjustments in the `Docstring.__init__` function within `_check_docs_utils.py` and changes in the `DocstringParameterChecker._compare_ignored_args` function within `docparams.py` to better handle the interplay between annotations and docstring documentation.",
      "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: useless-type-doc issued for undocumented parameters that have PEP484 type annotations\n\nBody:\n<!--\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\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:\npylint/extensions/_check_docs_utils.py\n  function: Docstring.__init__\n\npylint/extensions/docparams.py\n  line: line 23\n  function: DocstringParameterChecker._compare_ignored_args\n"
    },
    {
      "similar_issue": {
        "issue_title": "Missing parameter in documentation error code is the same as differing parameter (W9003)",
        "issue_body": "### Steps to reproduce\r\n1. Activate pylint.extensions.docparams\r\n.pylintrc -> `load-plugins=pylint.extensions.docparams`\r\n2. Create a function like the following\r\n````\r\ndef venv_with_kati(venva, kati):\r\n    \"\"\"\r\n    :param venv: virtualenv activation path\r\n    \"\"\"\r\n    print(kati, venva)\r\n````\r\n3. Run pylint\r\n\r\n### Current behavior\r\nCurrent behavior is to group the missing params in the same error with the invalid name params\r\n[W9003(missing-param-doc), bash_venv_or_null] \"kati, venv, venva\" missing or differing in parameter documentation\r\n\r\n### Expected behavior\r\nI would like to be able to disable warnings about missing params but at the same time still have warnings about obsolete named params. Something like the following:\r\n\r\n[W9003(missing-param-doc), bash_venv_or_null] \"kati, venva\" missing in parameter documentation\r\n***still the same***\r\n\r\n---\r\n\r\n[W900`**`(**invalid**-param-doc), bash_venv_or_null] \"venv\" documentation parameter missing from function signature\r\n***new error code***\r\n\r\n---\r\n\r\n### pylint --version output\r\n````\r\npylint --version\r\npylint 1.6.4,\r\nastroid 1.4.5\r\nPython 2.7.13 (default, Jan 12 2017, 17:59:37)\r\n[GCC 6.3.1 20161221 (Red Hat 6.3.1-1)]\r\n````\r\n\r\n",
        "issue_id": 1342,
        "pr_number": 1344,
        "pr_title": "Split missing+differing docstring param checks",
        "pr_body": "Add 2 different error codes for different params defined\r\nSplit param name checking in two functions, one for missing checks\r\nand another for different names checks\r\nCheck for missing params and then check for differing params\r\nMinor fix in type of found_argument_names [list --> set]\r\n\r\n### Fixes / new features\r\n- Fixes #1342\r\n",
        "issue_closed_at": "2017-03-11T07:06:58Z",
        "base_commit": "89d766ef8bea922cfacf55f8a8adbbf783955d4a"
      },
      "summary": "### Summary:\nThis issue is related to the behavior of the Pylint extension `pylint.extensions.docparams`, which is used to check for discrepancies between a function's parameters and its associated docstring documentation. The problem specifically arises when the extension generates a warning for missing parameters in the documentation and groups it together with warnings for parameters that are documented but not present in the function signature. \n\n1. **Problem Description in General Terms:** The Pylint extension is unable to differentiate between missing parameter documentation and parameters that are documented but not present in the function's signature, resulting in a single error code for both issues.\n\n2. **Key Symptoms and Behaviors Observed:** When running Pylint with the `pylint.extensions.docparams` plugin activated, users observe that the error code [W9003] is used both for parameters missing in the documentation and for those documented parameters that do not exist in the function signature. This behavior combines two distinct types of errors into one, making it difficult for users to selectively disable one without the other.\n\n3. **Affected Components or Systems:** The problem affects the Pylint extension `pylint.extensions.docparams`, specifically the way it handles parameter documentation checks within Python functions.\n\n4. **Potential Impact or Severity:** The impact mainly affects developers who rely on Pylint for code quality checks. It limits their ability to customize warnings, potentially leading to overlooked documentation issues or excessive noise from irrelevant warnings. This can reduce the overall efficiency of code reviews and quality assurance processes.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:** The issue lies in the design of the Pylint extension, where a single error code is used for both missing and incorrectly documented parameters. The proposed solution involves separating these warnings into distinct error codes to allow more granular control over which types of documentation discrepancies are flagged during static analysis. This would involve changes to the `DocstringParameterChecker` class in the `pylint/extensions/docparams.py` file, particularly in the logic of the `_compare_args` 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: Missing parameter in documentation error code is the same as differing parameter (W9003)\n\nBody:\n### Steps to reproduce\r\n1. Activate pylint.extensions.docparams\r\n.pylintrc -> `load-plugins=pylint.extensions.docparams`\r\n2. Create a function like the following\r\n````\r\ndef venv_with_kati(venva, kati):\r\n    \"\"\"\r\n    :param venv: virtualenv activation path\r\n    \"\"\"\r\n    print(kati, venva)\r\n````\r\n3. Run pylint\r\n\r\n### Current behavior\r\nCurrent behavior is to group the missing params in the same error with the invalid name params\r\n[W9003(missing-param-doc), bash_venv_or_null] \"kati, venv, venva\" missing or differing in parameter documentation\r\n\r\n### Expected behavior\r\nI would like to be able to disable warnings about missing params but at the same time still have warnings about obsolete named params. Something like the following:\r\n\r\n[W9003(missing-param-doc), bash_venv_or_null] \"kati, venva\" missing in parameter documentation\r\n***still the same***\r\n\r\n---\r\n\r\n[W900`**`(**invalid**-param-doc), bash_venv_or_null] \"venv\" documentation parameter missing from function signature\r\n***new error code***\r\n\r\n---\r\n\r\n### pylint --version output\r\n````\r\npylint --version\r\npylint 1.6.4,\r\nastroid 1.4.5\r\nPython 2.7.13 (default, Jan 12 2017, 17:59:37)\r\n[GCC 6.3.1 20161221 (Red Hat 6.3.1-1)]\r\n````\r\n\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:\npylint/extensions/docparams.py\n  class: DocstringParameterChecker\n  class: DocstringParameterChecker\n  function: DocstringParameterChecker._compare_args\n"
    },
    {
      "similar_issue": {
        "issue_title": "Crash ``'Attribute' object has no attribute 'name'`` in _check_unused_private_variables due to access via self.__class__",
        "issue_body": "\r\nWhen parsing the following file:\r\n\r\n<!--\r\n If sharing the code is not an option, please state so,\r\n but providing only the stacktrace would still be helpful.\r\n -->\r\n\r\n```python\r\nclass Foo:\r\n    __ham = 1\r\n\r\n    def foo():\r\n        print(self.__class__.__ham)\r\n\r\n```\r\n\r\npylint crashed with a ``AttributeError`` and with the following stacktrace:\r\n```\r\nTraceback (most recent call last):\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/lint/pylinter.py\", line 1008, in _check_files\r\n    self._check_file(get_ast, check_astroid_module, file)\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/lint/pylinter.py\", line 1043, in _check_file\r\n    check_astroid_module(ast_node)\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/lint/pylinter.py\", line 1180, in check_astroid_module\r\n    retval = self._check_astroid_module(\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/lint/pylinter.py\", line 1227, in _check_astroid_module\r\n    walker.walk(node)\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/utils/ast_walker.py\", line 78, in walk\r\n    self.walk(child)\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/utils/ast_walker.py\", line 80, in walk\r\n    callback(astroid)\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/checkers/classes.py\", line 907, in leave_classdef\r\n    self._check_unused_private_variables(node)\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/checkers/classes.py\", line 973, in _check_unused_private_variables\r\n    and child.expr.name in (\"self\", \"cls\", node.name)\r\nAttributeError: 'Attribute' object has no attribute 'name'\r\n```",
        "issue_id": 5261,
        "pr_number": 5262,
        "pr_title": "Fix crash on checking private members on ``__class__``",
        "pr_body": "- [x] Add yourself to CONTRIBUTORS if you are a new contributor.\r\n- [x] Add a ChangeLog entry describing what your PR does.\r\n- [x] If it's a new feature, or an important bug fix, add a What's New entry in\r\n      `doc/whatsnew/<current release.rst>`.\r\n- [x] Write a good description on what the PR does.\r\n\r\n## Type of Changes\r\n\r\n|     | Type                   |\r\n| --- | ---------------------- |\r\n| ✓   | :bug: Bug fix          |\r\n\r\n## Description\r\n\r\nCloses #5261\r\n",
        "issue_closed_at": "2021-11-05T20:26:54Z",
        "base_commit": "96e84595194073ea54a8c7730b86125049c0f4f9"
      },
      "summary": "### Summary:\nThis issue is related to a specific software crash occurring in the pylint tool, which is used for static code analysis in Python. The problem is triggered by an `AttributeError` caused by the tool's inability to correctly handle private variables accessed through `self.__class__` within a class method. This error manifests when pylint attempts to check for unused private variables in a Python file containing such a construct.\n\n1. **Problem Description in General Terms:**\n   The problem involves a software crash due to erroneous handling of class member access in Python. Specifically, when a class uses `self.__class__` to access a private variable, pylint fails to process this correctly, leading to an attribute error.\n\n2. **Key Symptoms and Behaviors Observed:**\n   The primary symptom is the crashing of pylint with an `AttributeError`. The error message indicates that an `'Attribute' object has no attribute 'name'`, which suggests that the tool incorrectly assumes that certain object attributes will always possess a `name` property.\n\n3. **Affected Components or Systems:**\n   The affected component is the pylint tool, specifically the part of its codebase responsible for checking unused private variables in Python classes. The error occurs within the `ClassChecker` module, particularly in the `_check_unused_private_variables` function.\n\n4. **Potential Impact or Severity:**\n   The severity of this issue can be considered moderate for developers using pylint, especially those employing private variables accessed via `self.__class__`. This crash halts the code analysis process, potentially delaying development workflows and hindering code quality checks.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   The root of the problem lies in pylint's internal mechanism for traversing and analyzing abstract syntax trees (ASTs) of Python code. The crash occurs when the tool improperly handles attributes of nodes within the AST, failing to account for cases where an attribute may not possess a `name` property. This suggests a need for improved handling of AST nodes, particularly in scenarios involving class-level attribute access patterns like `self.__class__`. The patch addresses this by updating the relevant functions in `pylint/checkers/classes.py`, ensuring robust checks against such attribute access patterns.",
      "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: Crash ``'Attribute' object has no attribute 'name'`` in _check_unused_private_variables due to access via self.__class__\n\nBody:\n\r\nWhen parsing the following file:\r\n\r\n<!--\r\n If sharing the code is not an option, please state so,\r\n but providing only the stacktrace would still be helpful.\r\n -->\r\n\r\n```python\r\nclass Foo:\r\n    __ham = 1\r\n\r\n    def foo():\r\n        print(self.__class__.__ham)\r\n\r\n```\r\n\r\npylint crashed with a ``AttributeError`` and with the following stacktrace:\r\n```\r\nTraceback (most recent call last):\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/lint/pylinter.py\", line 1008, in _check_files\r\n    self._check_file(get_ast, check_astroid_module, file)\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/lint/pylinter.py\", line 1043, in _check_file\r\n    check_astroid_module(ast_node)\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/lint/pylinter.py\", line 1180, in check_astroid_module\r\n    retval = self._check_astroid_module(\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/lint/pylinter.py\", line 1227, in _check_astroid_module\r\n    walker.walk(node)\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/utils/ast_walker.py\", line 78, in walk\r\n    self.walk(child)\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/utils/ast_walker.py\", line 80, in walk\r\n    callback(astroid)\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/checkers/classes.py\", line 907, in leave_classdef\r\n    self._check_unused_private_variables(node)\r\n  File \"/home/graingert/.local/pipx/.cache/1ea90594a10eda9/lib/python3.8/site-packages/pylint/checkers/classes.py\", line 973, in _check_unused_private_variables\r\n    and child.expr.name in (\"self\", \"cls\", node.name)\r\nAttributeError: 'Attribute' object has no attribute 'name'\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:\npylint/checkers/classes.py\n  function: ClassChecker._check_unused_private_functions\n  function: ClassChecker._check_unused_private_variables\n"
    },
    {
      "similar_issue": {
        "issue_title": "Pylint Crash on invalid TOML config",
        "issue_body": "### Steps to reproduce\r\n\r\nIt was not immediately clear to me that the main table should be `[tool.pylint.master]` and not `[tool.pylint]` (I searched in the docs but did not find an example).\r\n\r\nGiven any python file and a config file called `repro.toml` (I initially encountered this on my `pyproject.toml`, but for the sake of a simple example):\r\n\r\n```toml\r\n[tool.pylint]\r\nload-plugins = []\r\n```\r\n\r\n### Current behavior\r\n\r\n```\r\npylint --rcfile=repro.toml repro.py       \r\nTraceback (most recent call last):\r\n  File \"C:\\Program Files\\Python310\\lib\\runpy.py\", line 196, in _run_module_as_main\r\n    return _run_code(code, main_globals, None,\r\n  File \"C:\\Program Files\\Python310\\lib\\runpy.py\", line 86, in _run_code\r\n    exec(code, run_globals)\r\n  File \"D:\\...\\venv\\Scripts\\pylint.exe\\__main__.py\", line 7, in <module>\r\n  File \"d:\\...\\venv\\lib\\site-packages\\pylint\\__init__.py\", line 24, in run_pylint\r\n    PylintRun(sys.argv[1:])\r\n  File \"d:\\...\\venv\\lib\\site-packages\\pylint\\lint\\run.py\", line 316, in __init__\r\n    linter.read_config_file(verbose=self.verbose)\r\n  File \"d:\\...\\venv\\lib\\site-packages\\pylint\\config\\option_manager_mixin.py\", line 281, in read_config_file\r\n    for option, value in values.items():\r\nAttributeError: 'str' object has no attribute 'items'\r\n```\r\n\r\n### Expected behavior\r\n\r\nIt should not crash.\r\n\r\n### pylint --version output\r\n\r\nI just upgraded to prerelease versions as suggested in this template.\r\n\r\n```\r\npylint 3.0.0a3\r\nastroid 2.5.8\r\nPython 3.10.0b1 (tags/v3.10.0b1:ba42175, May  3 2021, 20:22:30) [MSC v.1928 64 bit (AMD64)]\r\n```\r\n\r\n### Additional crashes for invalid data\r\n\r\nAdditional crashes are possible for \"mapping\" configs where I thought a TOML table might be used rather than a list of strings with a built in separator as is used in `.pylintrc` (again, I could not find examples).\r\n\r\nGiven config:\r\n\r\n```toml\r\n[tool.pylint.imports]\r\npreferred-modules = { \"a\"=\"b\" }\r\n```\r\n\r\nOr config:\r\n\r\n```toml\r\n[tool.pylint.basic]\r\nname-group = { \"a\"=\"b\" }\r\n```\r\n\r\nResults in (same traceback for both configs):\r\n\r\n```\r\npylint --rcfile=repro.toml repro.py\r\nTraceback (most recent call last):\r\n  File \"C:\\Program Files\\Python310\\lib\\runpy.py\", line 196, in _run_module_as_main\r\n    return _run_code(code, main_globals, None,\r\n  File \"C:\\Program Files\\Python310\\lib\\runpy.py\", line 86, in _run_code\r\n    exec(code, run_globals)\r\n  File \"D:\\...\\venv\\Scripts\\pylint.exe\\__main__.py\", line 7, in <module>\r\n  File \"d:\\...\\venv\\lib\\site-packages\\pylint\\__init__.py\", line 24, in run_pylint\r\n    PylintRun(sys.argv[1:])\r\n  File \"d:\\...\\venv\\lib\\site-packages\\pylint\\lint\\run.py\", line 333, in __init__\r\n    linter.load_config_file()\r\n  File \"d:\\...\\venv\\lib\\site-packages\\pylint\\config\\option_manager_mixin.py\", line 313, in load_config_file\r\n    for option, value in parser.items(section):\r\n  File \"C:\\Program Files\\Python310\\lib\\configparser.py\", line 860, in items\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"C:\\Program Files\\Python310\\lib\\configparser.py\", line 860, in <listcomp>\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"C:\\Program Files\\Python310\\lib\\configparser.py\", line 856, in <lambda>\r\n    value_getter = lambda option: self._interpolation.before_get(self,\r\n  File \"C:\\Program Files\\Python310\\lib\\configparser.py\", line 395, in before_get\r\n    self._interpolate_some(parser, option, L, value, section, defaults, 1)\r\n  File \"C:\\Program Files\\Python310\\lib\\configparser.py\", line 412, in _interpolate_some\r\n    p = rest.find(\"%\")\r\nAttributeError: 'DynamicInlineTableDict' object has no attribute 'find'\r\n```\r\n\r\nRelated issues: #4518 #4204 ",
        "issue_id": 4580,
        "pr_number": 4720,
        "pr_title": "Pylint fix for invalid TOML config",
        "pr_body": "<!--\r\n\r\nThank you for submitting a PR to pylint!\r\n\r\nTo ease the process of reviewing your PR, do make sure to complete the following boxes.\r\n\r\nYou can also read more about contributing to pylint in this document:\r\nhttps://github.com/PyCQA/pylint/blob/main/doc/development_guide/contribute.rst#repository\r\n-->\r\n\r\n## Steps\r\n\r\n- [x] Add yourself to CONTRIBUTORS if you are a new contributor.\r\n- [ ] Add a ChangeLog entry describing what your PR does.\r\n- [ ] If it's a new feature or an important bug fix, add a What's New entry in\r\n      `doc/whatsnew/<current release.rst>`.\r\n- [x] Write a good description on what the PR does.\r\n\r\n## Description\r\nThis is a fix for handling bad or invalid toml configuration in pyproject.toml\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| ✓   | :sparkles: New feature |\r\n| ✓   | :hammer: Refactoring   |\r\n| ✓   | :scroll: Docs          |\r\n\r\n## Related Issue\r\n\r\n<!--\r\nIf this PR fixes a particular issue, use the following to automatically close that issue\r\nonce this PR gets merged:\r\n\r\nCloses #4580\r\n-->\r\nCloses #4580",
        "issue_closed_at": "2021-11-13T12:06:02Z",
        "base_commit": "7976857b94146f6ad81ade63797905cd662238c2"
      },
      "summary": "### Summary:\nThis issue involves the Pylint tool encountering a crash when processing invalid TOML configuration files. The problem arises due to improper handling of TOML table structures, which leads to AttributeError exceptions. Specifically, Pylint expects certain attributes in the configuration that are not present when TOML tables are incorrectly defined, resulting in crashes instead of graceful error handling.\n\n1. **Problem description in general terms:** \n   The issue occurs when Pylint is run with a misconfigured TOML file. The improper configuration, such as using incorrect table headers or mapping structures, leads to a crash instead of a user-friendly error message or behavior.\n\n2. **Key symptoms and behaviors observed:** \n   The primary symptom of this issue is a traceback error indicating an AttributeError, such as `'str' object has no attribute 'items'` or `'DynamicInlineTableDict' object has no attribute 'find'`. These errors occur when Pylint attempts to read and parse configuration options from the TOML file.\n\n3. **Affected components or systems:** \n   The components affected include the Pylint tool itself, particularly the modules responsible for reading and parsing configuration files, such as `option_manager_mixin.py` and `pylinter.py`.\n\n4. **Potential impact or severity:** \n   The impact of this issue can be significant for users relying on Pylint with TOML configurations, as it prevents the tool from running correctly, potentially halting development workflows. Users may face difficulties in configuring Pylint correctly due to the lack of clear examples or documentation, exacerbating the issue.\n\n5. **Any relevant technical details abstracted for broader understanding:** \n   The issue highlights the importance of robust error handling and user guidance in configuration file parsing. Ensuring that Pylint can gracefully handle misconfigurations and provide informative feedback can enhance user experience and tool reliability. The fixed code elements involve modifications to functions responsible for reading and parsing TOML configurations, aiming to prevent crashes and improve error messaging.",
      "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: Pylint Crash on invalid TOML config\n\nBody:\n### Steps to reproduce\r\n\r\nIt was not immediately clear to me that the main table should be `[tool.pylint.master]` and not `[tool.pylint]` (I searched in the docs but did not find an example).\r\n\r\nGiven any python file and a config file called `repro.toml` (I initially encountered this on my `pyproject.toml`, but for the sake of a simple example):\r\n\r\n```toml\r\n[tool.pylint]\r\nload-plugins = []\r\n```\r\n\r\n### Current behavior\r\n\r\n```\r\npylint --rcfile=repro.toml repro.py       \r\nTraceback (most recent call last):\r\n  File \"C:\\Program Files\\Python310\\lib\\runpy.py\", line 196, in _run_module_as_main\r\n    return _run_code(code, main_globals, None,\r\n  File \"C:\\Program Files\\Python310\\lib\\runpy.py\", line 86, in _run_code\r\n    exec(code, run_globals)\r\n  File \"D:\\...\\venv\\Scripts\\pylint.exe\\__main__.py\", line 7, in <module>\r\n  File \"d:\\...\\venv\\lib\\site-packages\\pylint\\__init__.py\", line 24, in run_pylint\r\n    PylintRun(sys.argv[1:])\r\n  File \"d:\\...\\venv\\lib\\site-packages\\pylint\\lint\\run.py\", line 316, in __init__\r\n    linter.read_config_file(verbose=self.verbose)\r\n  File \"d:\\...\\venv\\lib\\site-packages\\pylint\\config\\option_manager_mixin.py\", line 281, in read_config_file\r\n    for option, value in values.items():\r\nAttributeError: 'str' object has no attribute 'items'\r\n```\r\n\r\n### Expected behavior\r\n\r\nIt should not crash.\r\n\r\n### pylint --version output\r\n\r\nI just upgraded to prerelease versions as suggested in this template.\r\n\r\n```\r\npylint 3.0.0a3\r\nastroid 2.5.8\r\nPython 3.10.0b1 (tags/v3.10.0b1:ba42175, May  3 2021, 20:22:30) [MSC v.1928 64 bit (AMD64)]\r\n```\r\n\r\n### Additional crashes for invalid data\r\n\r\nAdditional crashes are possible for \"mapping\" configs where I thought a TOML table might be used rather than a list of strings with a built in separator as is used in `.pylintrc` (again, I could not find examples).\r\n\r\nGiven config:\r\n\r\n```toml\r\n[tool.pylint.imports]\r\npreferred-modules = { \"a\"=\"b\" }\r\n```\r\n\r\nOr config:\r\n\r\n```toml\r\n[tool.pylint.basic]\r\nname-group = { \"a\"=\"b\" }\r\n```\r\n\r\nResults in (same traceback for both configs):\r\n\r\n```\r\npylint --rcfile=repro.toml repro.py\r\nTraceback (most recent call last):\r\n  File \"C:\\Program Files\\Python310\\lib\\runpy.py\", line 196, in _run_module_as_main\r\n    return _run_code(code, main_globals, None,\r\n  File \"C:\\Program Files\\Python310\\lib\\runpy.py\", line 86, in _run_code\r\n    exec(code, run_globals)\r\n  File \"D:\\...\\venv\\Scripts\\pylint.exe\\__main__.py\", line 7, in <module>\r\n  File \"d:\\...\\venv\\lib\\site-packages\\pylint\\__init__.py\", line 24, in run_pylint\r\n    PylintRun(sys.argv[1:])\r\n  File \"d:\\...\\venv\\lib\\site-packages\\pylint\\lint\\run.py\", line 333, in __init__\r\n    linter.load_config_file()\r\n  File \"d:\\...\\venv\\lib\\site-packages\\pylint\\config\\option_manager_mixin.py\", line 313, in load_config_file\r\n    for option, value in parser.items(section):\r\n  File \"C:\\Program Files\\Python310\\lib\\configparser.py\", line 860, in items\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"C:\\Program Files\\Python310\\lib\\configparser.py\", line 860, in <listcomp>\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"C:\\Program Files\\Python310\\lib\\configparser.py\", line 856, in <lambda>\r\n    value_getter = lambda option: self._interpolation.before_get(self,\r\n  File \"C:\\Program Files\\Python310\\lib\\configparser.py\", line 395, in before_get\r\n    self._interpolate_some(parser, option, L, value, section, defaults, 1)\r\n  File \"C:\\Program Files\\Python310\\lib\\configparser.py\", line 412, in _interpolate_some\r\n    p = rest.find(\"%\")\r\nAttributeError: 'DynamicInlineTableDict' object has no attribute 'find'\r\n```\r\n\r\nRelated issues: #4518 #4204 \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:\npylint/config/option_manager_mixin.py\n  function: OptionsManagerMixIn.read_config_file\n  function: OptionsManagerMixIn._parse_toml\n\npylint/lint/pylinter.py\n  function: _load_reporter_by_class\n"
    },
    {
      "similar_issue": {
        "issue_title": "False positive for useless-suppression with cyclic-import",
        "issue_body": "I have a number of import cycles in my codebase, though I try to be safe about them by keeping them in functions and not at the module level.  In this case I suppress the cyclic-import warning within those individual functions.  I just enabled useless-suppression detection, however, and found that it is reporting (seemingly all?) of these cyclic-import suppressions as unnecessary, though when I remove them I once again get cyclic-import warnings.\r\n\r\n### Steps to reproduce\r\n1. create a.py with the following code:\r\n```\r\n\"\"\"Test Module A.\"\"\"\r\nimport b\r\n\r\nprint(b)\r\n```\r\n\r\n2. create b.py with the following code:\r\n```\r\n\"\"\"Test Module B.\"\"\"\r\n\r\ndef bfunc():\r\n    \"\"\"Create a 'safe-ish' import cycle by doing it from a function.\"\"\"\r\n    import a\r\n    print(a)\r\n```\r\n3. pylint --enable=cyclic-import a.py b.py -> should generate a warning\r\n4. add  # pylint: disable=cyclic-import under bfunc()\r\n5. pylint --enable=cyclic-import a.py b.py -> no warning now\r\n6. pylint --enable=cyclic-import,useless-suppression a.py b.py -> incorrectly states that the line we added in step 4 is unnecessary\r\n\r\n### Current behavior\r\nI'm finding all of my cyclic-import suppressions are generating these warnings.\r\n\r\n### Expected behavior\r\nShould useless-suppression detection simply ignore cyclic-import suppressions?  Even if it was behaving as expected in this test case, would it still trigger incorrectly if only a.py or b.py were tested by itself?  (pylint only generates the cycle error when both a.py and b.py are tested together)\r\n\r\n### pylint --version output\r\npylint 2.3.1\r\nastroid 2.2.5\r\nPython 3.7.4 (default, Jul  9 2019, 18:13:23) \r\n[Clang 10.0.1 (clang-1001.0.46.4)]\r\n",
        "issue_id": 3064,
        "pr_number": 3071,
        "pr_title": "useless-suppression detection now ignores cyclic-import",
        "pr_body": "<!--\r\n\r\nThank you for submitting a PR to pylint!\r\n\r\nTo ease the process of reviewing your PR, do make sure to complete the following boxes.\r\n\r\nYou can also read more about contributing to pylint in this document:\r\nhttps://github.com/PyCQA/pylint/blob/master/doc/development_guide/contribute.rst#repository\r\n-->\r\n\r\n## Steps\r\n\r\n- [X] Add yourself to CONTRIBUTORS if you are a new contributor.\r\n- [X] Add a ChangeLog entry describing what your PR does.\r\n- [ ] If it's a new feature or an important bug fix, add a What's New entry in `doc/whatsnew/<current release.rst>`.\r\n- [X] Write a good description on what the PR does.\r\n\r\n## Description\r\nThis simply tweaks iter_spurious_suppression_messages() to ignore any 'R0401' warnings it comes across (cyclic-import). The cyclic-import checker seems to have incomplete context at the point when this runs so is always flagged as a useless suppression.\r\nPlease holler if this is not the best place to add the ignore; happy to revise the PR if needed.\r\n\r\n## Type of Changes\r\n<!-- Leave the corresponding lines for the applicable type of change: -->\r\n|   | Type |\r\n| ------------- | ------------- |\r\n| ✓  | :bug: Bug fix  |\r\n\r\n## Related Issue\r\nCloses #3064 \r\n<!-- \r\nIf this PR fixes a particular issue, use the following to automatically close that issue\r\nonce this PR gets merged:\r\n\r\nCloses #xxx\r\n-->",
        "issue_closed_at": "2019-08-22T12:37:04Z",
        "base_commit": "ac25a275afe489e7ddf24ff6fd078414854ebaa4"
      },
      "summary": "### Summary:\nThis issue involves a false positive detection of \"useless-suppression\" warnings by Pylint when cyclic-import warnings are suppressed within functions. The problem arises in codebases with import cycles, where import statements are strategically placed inside functions to mitigate cyclic dependencies. When the user enables Pylint's \"useless-suppression\" detection, these suppressions are erroneously flagged as unnecessary, even though removing them results in the reappearance of cyclic-import warnings.\n\n1. **Problem description in general terms:** The problem concerns a tool (Pylint) incorrectly identifying certain warning suppressions as superfluous, specifically in the context of cyclic-import warnings within Python code, when these suppressions are function-scoped rather than module-scoped.\n\n2. **Key symptoms and behaviors observed:** The main symptom is the generation of \"useless-suppression\" warnings for cyclic-import suppressions inside functions. When these suppressions are removed, cyclic-import warnings reappear, indicating that the suppressions were indeed necessary.\n\n3. **Affected components or systems:** The issue affects the Pylint tool, particularly its functionality related to the detection of unnecessary warning suppressions when evaluating Python files that may contain import cycles.\n\n4. **Potential impact or severity:** The impact is primarily on developers who rely on Pylint for code quality checks. It could lead to confusion and unnecessary code modifications, as developers may wrongly believe their suppressions are not needed. This can disrupt workflow efficiency and potentially cause developers to overlook legitimate issues due to the noise of false positives.\n\n5. **Relevant technical details abstracted for broader understanding:** The issue is observed with Pylint version 2.3.1, using Python 3.7.4. The problem is specific to scenarios where cyclic-import warnings are strategically suppressed inside functions to manage import cycles, and \"useless-suppression\" checks are enabled. The behavior is consistent only when all involved files are analyzed together, as individual file checks do not trigger the cyclic-import warnings.",
      "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: False positive for useless-suppression with cyclic-import\n\nBody:\nI have a number of import cycles in my codebase, though I try to be safe about them by keeping them in functions and not at the module level.  In this case I suppress the cyclic-import warning within those individual functions.  I just enabled useless-suppression detection, however, and found that it is reporting (seemingly all?) of these cyclic-import suppressions as unnecessary, though when I remove them I once again get cyclic-import warnings.\r\n\r\n### Steps to reproduce\r\n1. create a.py with the following code:\r\n```\r\n\"\"\"Test Module A.\"\"\"\r\nimport b\r\n\r\nprint(b)\r\n```\r\n\r\n2. create b.py with the following code:\r\n```\r\n\"\"\"Test Module B.\"\"\"\r\n\r\ndef bfunc():\r\n    \"\"\"Create a 'safe-ish' import cycle by doing it from a function.\"\"\"\r\n    import a\r\n    print(a)\r\n```\r\n3. pylint --enable=cyclic-import a.py b.py -> should generate a warning\r\n4. add  # pylint: disable=cyclic-import under bfunc()\r\n5. pylint --enable=cyclic-import a.py b.py -> no warning now\r\n6. pylint --enable=cyclic-import,useless-suppression a.py b.py -> incorrectly states that the line we added in step 4 is unnecessary\r\n\r\n### Current behavior\r\nI'm finding all of my cyclic-import suppressions are generating these warnings.\r\n\r\n### Expected behavior\r\nShould useless-suppression detection simply ignore cyclic-import suppressions?  Even if it was behaving as expected in this test case, would it still trigger incorrectly if only a.py or b.py were tested by itself?  (pylint only generates the cycle error when both a.py and b.py are tested together)\r\n\r\n### pylint --version output\r\npylint 2.3.1\r\nastroid 2.2.5\r\nPython 3.7.4 (default, Jul  9 2019, 18:13:23) \r\n[Clang 10.0.1 (clang-1001.0.46.4)]\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:\npylint/utils/file_state.py\n  function: FileState.iter_spurious_suppression_messages\n"
    }
  ]
}