{
  "original_problem": {
    "instance_id": "pylint-dev__pylint-7228",
    "repo": "pylint-dev/pylint",
    "created_at": "2022-07-25T17:19:11Z",
    "problem_statement": "rxg include '\\p{Han}' will throw error\n### Bug description\r\n\r\nconfig rxg in pylintrc with \\p{Han} will throw err\r\n\r\n### Configuration\r\n.pylintrc:\r\n\r\n```ini\r\nfunction-rgx=[\\p{Han}a-z_][\\p{Han}a-z0-9_]{2,30}$\r\n```\r\n\r\n### Command used\r\n\r\n```shell\r\npylint\r\n```\r\n\r\n\r\n### Pylint output\r\n\r\n```shell\r\n(venvtest) tsung-hande-MacBook-Pro:robot_is_comming tsung-han$ pylint\r\nTraceback (most recent call last):\r\n  File \"/Users/tsung-han/PycharmProjects/robot_is_comming/venvtest/bin/pylint\", line 8, in <module>\r\n    sys.exit(run_pylint())\r\n  File \"/Users/tsung-han/PycharmProjects/robot_is_comming/venvtest/lib/python3.9/site-packages/pylint/__init__.py\", line 25, in run_pylint\r\n    PylintRun(argv or sys.argv[1:])\r\n  File \"/Users/tsung-han/PycharmProjects/robot_is_comming/venvtest/lib/python3.9/site-packages/pylint/lint/run.py\", line 161, in __init__\r\n    args = _config_initialization(\r\n  File \"/Users/tsung-han/PycharmProjects/robot_is_comming/venvtest/lib/python3.9/site-packages/pylint/config/config_initialization.py\", line 57, in _config_initialization\r\n    linter._parse_configuration_file(config_args)\r\n  File \"/Users/tsung-han/PycharmProjects/robot_is_comming/venvtest/lib/python3.9/site-packages/pylint/config/arguments_manager.py\", line 244, in _parse_configuration_file\r\n    self.config, parsed_args = self._arg_parser.parse_known_args(\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/argparse.py\", line 1858, in parse_known_args\r\n    namespace, args = self._parse_known_args(args, namespace)\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/argparse.py\", line 2067, in _parse_known_args\r\n    start_index = consume_optional(start_index)\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/argparse.py\", line 2007, in consume_optional\r\n    take_action(action, args, option_string)\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/argparse.py\", line 1919, in take_action\r\n    argument_values = self._get_values(action, argument_strings)\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/argparse.py\", line 2450, in _get_values\r\n    value = self._get_value(action, arg_string)\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/argparse.py\", line 2483, in _get_value\r\n    result = type_func(arg_string)\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/re.py\", line 252, in compile\r\n    return _compile(pattern, flags)\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/re.py\", line 304, in _compile\r\n    p = sre_compile.compile(pattern, flags)\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/sre_compile.py\", line 788, in compile\r\n    p = sre_parse.parse(p, flags)\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/sre_parse.py\", line 955, in parse\r\n    p = _parse_sub(source, state, flags & SRE_FLAG_VERBOSE, 0)\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/sre_parse.py\", line 444, in _parse_sub\r\n    itemsappend(_parse(source, state, verbose, nested + 1,\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/sre_parse.py\", line 555, in _parse\r\n    code1 = _class_escape(source, this)\r\n  File \"/usr/local/Cellar/python@3.9/3.9.13_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/sre_parse.py\", line 350, in _class_escape\r\n    raise source.error('bad escape %s' % escape, len(escape))\r\nre.error: bad escape \\p at position 1\r\n```\r\n\r\n### Expected behavior\r\n\r\nnot throw error\r\n\r\n### Pylint version\r\n\r\n```shell\r\npylint 2.14.4\r\nastroid 2.11.7\r\nPython 3.9.13 (main, May 24 2022, 21:28:44) \r\n[Clang 13.0.0 (clang-1300.0.29.30)]\r\n```\r\n\r\n\r\n### OS / Environment\r\n\r\nmacOS 11.6.7\r\n\n",
    "patch": "diff --git a/pylint/config/argument.py b/pylint/config/argument.py\n--- a/pylint/config/argument.py\n+++ b/pylint/config/argument.py\n@@ -99,11 +99,20 @@ def _py_version_transformer(value: str) -> tuple[int, ...]:\n     return version\n \n \n+def _regex_transformer(value: str) -> Pattern[str]:\n+    \"\"\"Return `re.compile(value)`.\"\"\"\n+    try:\n+        return re.compile(value)\n+    except re.error as e:\n+        msg = f\"Error in provided regular expression: {value} beginning at index {e.pos}: {e.msg}\"\n+        raise argparse.ArgumentTypeError(msg)\n+\n+\n def _regexp_csv_transfomer(value: str) -> Sequence[Pattern[str]]:\n     \"\"\"Transforms a comma separated list of regular expressions.\"\"\"\n     patterns: list[Pattern[str]] = []\n     for pattern in _csv_transformer(value):\n-        patterns.append(re.compile(pattern))\n+        patterns.append(_regex_transformer(pattern))\n     return patterns\n \n \n@@ -130,7 +139,7 @@ def _regexp_paths_csv_transfomer(value: str) -> Sequence[Pattern[str]]:\n     \"non_empty_string\": _non_empty_string_transformer,\n     \"path\": _path_transformer,\n     \"py_version\": _py_version_transformer,\n-    \"regexp\": re.compile,\n+    \"regexp\": _regex_transformer,\n     \"regexp_csv\": _regexp_csv_transfomer,\n     \"regexp_paths_csv\": _regexp_paths_csv_transfomer,\n     \"string\": pylint_utils._unquote,\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_4580",
        "decision": "Useful",
        "confidence": "Medium",
        "reason": "Both issues involve configuration parsing errors in Pylint, requiring improved error handling and documentation."
      },
      {
        "idx": 2,
        "id": "similar_2610",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is related to AST processing errors, which is different from configuration parsing errors."
      },
      {
        "idx": 3,
        "id": "similar_4412",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about compatibility with Python versions, unrelated to regex parsing or configuration errors."
      },
      {
        "idx": 4,
        "id": "similar_3064",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves false positives in suppression detection, unrelated to regex parsing or configuration errors."
      },
      {
        "idx": 5,
        "id": "similar_461",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about code formatting errors, unrelated to regex parsing or configuration errors."
      }
    ]
  },
  "raw_summaries": [
    {
      "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 is related to the `pylint` tool encountering a crash when processing invalid TOML configuration files. Specifically, the problem arises when the configuration tables within the TOML file are incorrectly structured, leading to an `AttributeError` in the execution of `pylint`. The crash occurs because `pylint` expects certain TOML structures that are not properly documented, causing confusion among users attempting to configure `pylint` via TOML files.\n\n1. **Problem description in general terms**: \n   The issue involves `pylint` crashing due to incorrect TOML configurations. Users mistakenly configure `pylint` using TOML structures that the tool does not handle correctly, primarily because of unclear documentation on the expected structure.\n\n2. **Key symptoms and behaviors observed**:\n   - A traceback error is displayed when running `pylint` with an invalid TOML configuration, indicating an `AttributeError`.\n   - The error messages point to issues where `pylint` attempts to access attributes or methods that are not present, such as trying to iterate over a string or handling a `DynamicInlineTableDict` object incorrectly.\n\n3. **Affected components or systems**:\n   - The `pylint` tool's configuration processing components are affected, specifically within the modules `pylint/config/option_manager_mixin.py` and `pylint/lint/pylinter.py`.\n\n4. **Potential impact or severity**:\n   - The severity of the issue is moderate as it can prevent users from successfully running `pylint` with TOML configurations, potentially disrupting workflows that rely on automated code analysis.\n   - Users may experience frustration or confusion, especially if they cannot find adequate documentation to guide them in creating valid TOML configurations.\n\n5. **Relevant technical details abstracted for broader understanding**:\n   - The issue stems from `pylint`'s inability to correctly interpret certain TOML structures, specifically tables not nested under expected categories.\n   - The fix involves modifying functions such as `OptionsManagerMixIn.read_config_file` and `OptionsManagerMixIn._parse_toml` to handle different TOML structures more gracefully.\n   - There is a need for improved documentation or examples to guide users in properly structuring their TOML configuration files for `pylint`.",
      "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": "New implicit-str-concat-in-sequence crashes",
        "issue_body": "### Current behavior\r\n```\r\n00:02:04.979 Traceback (most recent call last):\r\n00:02:04.979   File \"/home/jenkins/venv/4/bin/pylint\", line 11, in <module>\r\n00:02:04.979     sys.exit(run_pylint())\r\n00:02:04.979   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/__init__.py\", line 20, in run_pylint\r\n00:02:04.979     Run(sys.argv[1:])\r\n00:02:04.979   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/lint.py\", line 1608, in __init__\r\n00:02:04.979     linter.check(args)\r\n00:02:04.979   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/lint.py\", line 938, in check\r\n00:02:04.979     self._do_check(files_or_modules)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/lint.py\", line 1071, in _do_check\r\n00:02:04.980     self.check_astroid_module(ast_node, walker, rawcheckers, tokencheckers)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/lint.py\", line 1154, in check_astroid_module\r\n00:02:04.980     walker.walk(ast_node)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/utils.py\", line 1269, in walk\r\n00:02:04.980     self.walk(child)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/utils.py\", line 1269, in walk\r\n00:02:04.980     self.walk(child)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/utils.py\", line 1269, in walk\r\n00:02:04.980     self.walk(child)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/utils.py\", line 1266, in walk\r\n00:02:04.980     cb(astroid)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/checkers/strings.py\", line 613, in visit_tuple\r\n00:02:04.980     self.check_for_concatenated_strings(node, \"tuple\")\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/checkers/strings.py\", line 622, in check_for_concatenated_strings\r\n00:02:04.980     (elt.lineno, elt.col_offset)\r\n00:02:04.980 KeyError: (5, 39)\r\n```\r\n\r\nI'll try to find the crash-causing code.\r\n### Expected behavior\r\nDo not crash ;)\r\n\r\n### pylint --version output\r\npylint 2.2.0\r\nastroid 2.1.0\r\nPython 3.6.7 (default, Nov 22 2018, 09:26:21) \r\n[GCC 8.2.1 20180831]\r\n",
        "issue_id": 2610,
        "pr_number": 2611,
        "pr_title": "implicit-str-concat-in-sequence: Handling lines with multi-bytes characters - fix #2610",
        "pr_body": "",
        "issue_closed_at": "2018-11-26T13:22:07Z",
        "base_commit": "1ac83855b38a8d053ec5d0403a5c0e6e8b191fbb"
      },
      "summary": "### Summary:\nThis issue is related to a crash in the pylint tool, specifically when processing certain Python code that involves string concatenation within tuples. The error occurs during the analysis of abstract syntax trees (AST), where the tool attempts to handle concatenated strings but encounters a `KeyError`, implying that the expected key is missing during execution. The affected component is the `StringConstantChecker` class within the `pylint/checkers/strings.py` module, particularly in the `process_module` and `check_for_concatenated_strings` functions.\n\n1. **Problem description in general terms**:\n   The problem involves an unexpected crash in a static code analysis tool while processing a sequence of string concatenations in Python code. The crash is due to the tool's inability to handle certain edge cases in its string checking logic.\n\n2. **Key symptoms and behaviors observed**:\n   - The tool crashes with a traceback error message pointing to a `KeyError`.\n   - The error message indicates that the issue arises when the tool attempts to process a tuple containing implicitly concatenated strings.\n\n3. **Affected components or systems**:\n   - The `StringConstantChecker` in the pylint codebase, specifically in functions related to processing modules and handling concatenated strings.\n\n4. **Potential impact or severity**:\n   - The severity of the issue is significant for users relying on pylint for code analysis, as it prevents successful analysis and reports a crash instead.\n   - This issue could disrupt automated code quality checks in integration and deployment pipelines, potentially delaying development processes.\n\n5. **Relevant technical details abstracted for broader understanding**:\n   - The crash occurs due to a missing key in a dictionary-like structure, indicating a possible oversight in the handling of AST nodes.\n   - The problem affects pylint version 2.2.0 running on Python 3.6.7, suggesting a need for updates or patches in the tool's handling of string concatenation cases in ASTs.",
      "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: New implicit-str-concat-in-sequence crashes\n\nBody:\n### Current behavior\r\n```\r\n00:02:04.979 Traceback (most recent call last):\r\n00:02:04.979   File \"/home/jenkins/venv/4/bin/pylint\", line 11, in <module>\r\n00:02:04.979     sys.exit(run_pylint())\r\n00:02:04.979   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/__init__.py\", line 20, in run_pylint\r\n00:02:04.979     Run(sys.argv[1:])\r\n00:02:04.979   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/lint.py\", line 1608, in __init__\r\n00:02:04.979     linter.check(args)\r\n00:02:04.979   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/lint.py\", line 938, in check\r\n00:02:04.979     self._do_check(files_or_modules)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/lint.py\", line 1071, in _do_check\r\n00:02:04.980     self.check_astroid_module(ast_node, walker, rawcheckers, tokencheckers)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/lint.py\", line 1154, in check_astroid_module\r\n00:02:04.980     walker.walk(ast_node)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/utils.py\", line 1269, in walk\r\n00:02:04.980     self.walk(child)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/utils.py\", line 1269, in walk\r\n00:02:04.980     self.walk(child)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/utils.py\", line 1269, in walk\r\n00:02:04.980     self.walk(child)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/utils.py\", line 1266, in walk\r\n00:02:04.980     cb(astroid)\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/checkers/strings.py\", line 613, in visit_tuple\r\n00:02:04.980     self.check_for_concatenated_strings(node, \"tuple\")\r\n00:02:04.980   File \"/home/jenkins/venv/4/lib/python3.6/site-packages/pylint/checkers/strings.py\", line 622, in check_for_concatenated_strings\r\n00:02:04.980     (elt.lineno, elt.col_offset)\r\n00:02:04.980 KeyError: (5, 39)\r\n```\r\n\r\nI'll try to find the crash-causing code.\r\n### Expected behavior\r\nDo not crash ;)\r\n\r\n### pylint --version output\r\npylint 2.2.0\r\nastroid 2.1.0\r\nPython 3.6.7 (default, Nov 22 2018, 09:26:21) \r\n[GCC 8.2.1 20180831]\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/strings.py\n  function: StringConstantChecker.process_module\n  function: StringConstantChecker.check_for_concatenated_strings\n"
    },
    {
      "similar_issue": {
        "issue_title": "Problem importing module strings.py: cannot import name 'Counter'",
        "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\nOn python 3.6.0, usage of pylint 2.8.2 results in an import warning to stdout.  \r\n\r\nN.B. `typing.Counter` was added in python 3.6.1, so this import probably needs to be wrapped in a `TYPE_CHECKING` guard.\r\n\r\n(Yes, I know 3.6.0 is an old patch release. Still have it on some CI servers for unfortunate reasons.)\r\n\r\n### Steps to reproduce\r\n\r\nGiven that this warning seems to be coming from `register_plugins()` in utils.py, it is probably reproducible with any input file.\r\n\r\n### Current behavior\r\n\r\nPrinted message: `Problem importing module strings.py: cannot import name 'Counter'`\r\n\r\n### Expected behavior\r\n\r\nNo warning, and `strings` checker works as expected.\r\n\r\n### pylint --version output\r\n\r\nResult of `pylint --version` output:\r\n\r\n```\r\npylint 2.8.2\r\nastroid 2.5.6\r\nPython 3.6.0 (default, Jan 23 2017, 20:01:14) [MSC v.1900 64 bit (AMD64)]\r\n```\r\n",
        "issue_id": 4412,
        "pr_number": 4446,
        "pr_title": "Fix issues with Python 3.6.0",
        "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- [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## Description\r\n\r\nThis PR fixes compatibility with Python 3.6.0, mainly due to `typing`:\r\n\r\n- `typing.Counter` is added in Python 3.6.1, so make the import conditional on TYPE_CHECKING.\r\n- `typing.NoReturn` is added in Python 3.6.2, split the inconsistent_returns tests that need this to it's own file.\r\n- `black`, `pre-commit` and `pyupgrade` require Python 3.6.1 (or later), add `python_full_version` markers so `tox -e py36` works\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\nCloses #4412 ",
        "issue_closed_at": "2021-05-12T11:40:15Z",
        "base_commit": "9b268ecedb1c3dbfd24f5edb0c891266f988b87a"
      },
      "summary": "### Summary:\n\nThis issue pertains to a compatibility problem encountered when using pylint 2.8.2 with Python 3.6.0, specifically related to importing the 'Counter' class from the 'typing' module. The problem arises because the 'Counter' class was only introduced in Python 3.6.1, causing an import error in environments still using Python 3.6.0. This results in a warning message indicating a failure to import 'Counter' from 'strings.py' within pylint's internal utilities. \n\nKey symptoms include the display of an import warning message when running pylint, which potentially disrupts the expected functionality of pylint's string checking features. The main component impacted by this issue is the 'register_plugins()' function in the 'utils.py' module of pylint, which is responsible for handling plugin registration that subsequently fails due to the missing import.\n\nThe severity of this issue may vary depending on the reliance on Python 3.6.0 in certain environments, particularly in continuous integration (CI) systems that have not been updated to newer Python versions due to legacy dependencies or other constraints.\n\nTechnical considerations suggest that a conditional import using a `TYPE_CHECKING` guard can resolve the problem by ensuring compatibility across different Python versions. This approach prevents the import attempt when the class is unavailable, thus allowing pylint to function without warnings or errors on older versions of Python.\n\nThe code fix involves modifications in the 'strings.py' checker of pylint, likely around the lines where the 'Counter' class is imported and utilized.",
      "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: Problem importing module strings.py: cannot import name 'Counter'\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\nOn python 3.6.0, usage of pylint 2.8.2 results in an import warning to stdout.  \r\n\r\nN.B. `typing.Counter` was added in python 3.6.1, so this import probably needs to be wrapped in a `TYPE_CHECKING` guard.\r\n\r\n(Yes, I know 3.6.0 is an old patch release. Still have it on some CI servers for unfortunate reasons.)\r\n\r\n### Steps to reproduce\r\n\r\nGiven that this warning seems to be coming from `register_plugins()` in utils.py, it is probably reproducible with any input file.\r\n\r\n### Current behavior\r\n\r\nPrinted message: `Problem importing module strings.py: cannot import name 'Counter'`\r\n\r\n### Expected behavior\r\n\r\nNo warning, and `strings` checker works as expected.\r\n\r\n### pylint --version output\r\n\r\nResult of `pylint --version` output:\r\n\r\n```\r\npylint 2.8.2\r\nastroid 2.5.6\r\nPython 3.6.0 (default, Jan 23 2017, 20:01:14) [MSC v.1900 64 bit (AMD64)]\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/checkers/strings.py\n  line: line 38\n  line: line 46\n  function: StringConstantChecker.check_for_consistent_string_delimiters\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 concerns a false positive detection of unnecessary suppression warnings in the pylint tool, specifically related to cyclic-import warnings. In a codebase with import cycles managed within function scopes to avoid module-level cycles, the user suppresses cyclic-import warnings using pylint directives. However, upon enabling the \"useless-suppression\" detection, pylint incorrectly flags these suppression directives as unnecessary, despite their necessity to prevent cyclic-import warnings.\n\n1. **Problem description in general terms**: The problem arises from a misinterpretation by the pylint tool, which incorrectly identifies valid suppression directives as redundant when they are actually needed to prevent cyclic-import warnings in code with function-scoped import cycles.\n\n2. **Key symptoms and behaviors observed**: Users experience false positive warnings from the \"useless-suppression\" detection feature of pylint. When these suppressions are removed based on the false positive, cyclic-import warnings reappear, indicating their necessity.\n\n3. **Affected components or systems**: The issue affects the suppression detection capabilities in pylint, specifically the interaction between cyclic-import warnings and the useless-suppression detection feature.\n\n4. **Potential impact or severity**: The severity is moderate as it leads to confusion and potential misconfiguration in user codebases. It forces developers to choose between ignoring false positives or dealing with redundant warnings, which can disrupt workflow and code quality checks.\n\n5. **Any relevant technical details abstracted for broader understanding**: The issue is observed when pylint is run with both cyclic-import and useless-suppression checks enabled. The problem manifests primarily when the codebase is tested in parts rather than as a whole, as the cyclic-import warning emerges only when the complete import cycle is analyzed together. The issue is specifically tied to the misinterpretation within the function `FileState.iter_spurious_suppression_messages` in the pylint/utils/file_state.py file, which affects the suppression logic.",
      "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"
    },
    {
      "similar_issue": {
        "issue_title": "incorrect hanging indent detection with 'with' statement",
        "issue_body": "Originally reported by: **Dylan Baker (BitBucket: [dylan_baker](http://bitbucket.org/dylan_baker))**\n\n---\n\nPylint incorrectly marks hanging intdent errors when using multiline context managers, that use a double indent. Below is a trivial example.\n\n``` python\n\n#!/usr/bin/python2.7\n\nfrom __future__ import print_function\nfrom contextlib import contextmanager\n\n\n@contextmanager\ndef a_manager(thing1, thing2, thing3):\n    yield lambda x, y: print(thing1, thing2, thing3, x, y)\n\n\n# Pylint will Mark the arguments to a_manager as a bad hanging indent\nwith a_manager(\n        \"my really freakin' long string, it's long enough for a new line\",\n        \"it's another realy long string.\",\n        \"this one is short.\") as f:\n    f(1, 2)\n\n# This is okay\nwith a_manager(\"A long enough string I need a newline\",\n               \"Cuz this is also a long string or staement.\",\n               \"but not this.\") as f:\n    f(1, 2)\n\n\n# so is this\nif (\"this string is super mega awesome long string\" and\n        \"Also this really long string or comprasison or whatever\"):\n    print(\"Yay\")\n\n\n```\n\n---\n- Bitbucket: https://bitbucket.org/logilab/pylint/issue/461\n",
        "issue_id": 461,
        "pr_number": 2282,
        "pr_title": "Fix incorrect hanging indent detection for with statements",
        "pr_body": "Add with statement to recognized token keywords for format checker.\r\nAlso recognize with statement as the start of a block\r\nto allow deeper indentation for hanging continuation\r\n\r\nClose #461\r\n",
        "issue_closed_at": "2018-07-15T07:26:23Z",
        "base_commit": "5f9b46c0d45aa1fef67283a96062ff5de25a1263"
      },
      "summary": "### Summary: This issue pertains to an incorrect detection of hanging indentations by the static code analysis tool, Pylint, when processing multiline context managers that utilize a double indent. The problem manifests when Pylint erroneously flags certain correctly formatted code as having a hanging indent error. Specifically, this occurs in scenarios where the context manager's arguments are spread across multiple lines, requiring additional indentation for readability. The incorrect behavior is contrasted with other similar code structures that Pylint evaluates correctly, such as multi-line conditional statements. The problem impacts Pylint's functionality, particularly in the module responsible for analyzing code formatting, and may lead to false positives in linting reports, potentially causing confusion or unnecessary code changes by developers. The severity of this issue is moderate as it affects the accuracy and reliability of static code analysis outputs. The technical fix involved modifications to specific functions within the `pylint/checkers/format.py` file, which manage the validation of indentation in continued lines.",
      "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: incorrect hanging indent detection with 'with' statement\n\nBody:\nOriginally reported by: **Dylan Baker (BitBucket: [dylan_baker](http://bitbucket.org/dylan_baker))**\n\n---\n\nPylint incorrectly marks hanging intdent errors when using multiline context managers, that use a double indent. Below is a trivial example.\n\n``` python\n\n#!/usr/bin/python2.7\n\nfrom __future__ import print_function\nfrom contextlib import contextmanager\n\n\n@contextmanager\ndef a_manager(thing1, thing2, thing3):\n    yield lambda x, y: print(thing1, thing2, thing3, x, y)\n\n\n# Pylint will Mark the arguments to a_manager as a bad hanging indent\nwith a_manager(\n        \"my really freakin' long string, it's long enough for a new line\",\n        \"it's another realy long string.\",\n        \"this one is short.\") as f:\n    f(1, 2)\n\n# This is okay\nwith a_manager(\"A long enough string I need a newline\",\n               \"Cuz this is also a long string or staement.\",\n               \"but not this.\") as f:\n    f(1, 2)\n\n\n# so is this\nif (\"this string is super mega awesome long string\" and\n        \"Also this really long string or comprasison or whatever\"):\n    print(\"Yay\")\n\n\n```\n\n---\n- Bitbucket: https://bitbucket.org/logilab/pylint/issue/461\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/format.py\n  line: line 47\n  function: ContinuedLineState.get_valid_indentations\n  function: ContinuedLineState._hanging_indent_after_bracket\n  function: ContinuedLineState._continuation_inside_bracket\n"
    }
  ]
}