{
  "original_problem": {
    "instance_id": "pylint-dev__pylint-7993",
    "repo": "pylint-dev/pylint",
    "created_at": "2022-12-27T18:20:50Z",
    "problem_statement": "Using custom braces in message template does not work\n### Bug description\n\nHave any list of errors:\r\n\r\nOn pylint 1.7 w/ python3.6 - I am able to use this as my message template\r\n```\r\n$ pylint test.py --msg-template='{{ \"Category\": \"{category}\" }}'\r\nNo config file found, using default configuration\r\n************* Module [redacted].test\r\n{ \"Category\": \"convention\" }\r\n{ \"Category\": \"error\" }\r\n{ \"Category\": \"error\" }\r\n{ \"Category\": \"convention\" }\r\n{ \"Category\": \"convention\" }\r\n{ \"Category\": \"convention\" }\r\n{ \"Category\": \"error\" }\r\n```\r\n\r\nHowever, on Python3.9 with Pylint 2.12.2, I get the following:\r\n```\r\n$ pylint test.py --msg-template='{{ \"Category\": \"{category}\" }}'\r\n[redacted]/site-packages/pylint/reporters/text.py:206: UserWarning: Don't recognize the argument '{ \"Category\"' in the --msg-template. Are you sure it is supported on the current version of pylint?\r\n  warnings.warn(\r\n************* Module [redacted].test\r\n\" }\r\n\" }\r\n\" }\r\n\" }\r\n\" }\r\n\" }\r\n```\r\n\r\nIs this intentional or a bug?\n\n### Configuration\n\n_No response_\n\n### Command used\n\n```shell\npylint test.py --msg-template='{{ \"Category\": \"{category}\" }}'\n```\n\n\n### Pylint output\n\n```shell\n[redacted]/site-packages/pylint/reporters/text.py:206: UserWarning: Don't recognize the argument '{ \"Category\"' in the --msg-template. Are you sure it is supported on the current version of pylint?\r\n  warnings.warn(\r\n************* Module [redacted].test\r\n\" }\r\n\" }\r\n\" }\r\n\" }\r\n\" }\r\n\" }\n```\n\n\n### Expected behavior\n\nExpect the dictionary to print out with `\"Category\"` as the key.\n\n### Pylint version\n\n```shell\nAffected Version:\r\npylint 2.12.2\r\nastroid 2.9.2\r\nPython 3.9.9+ (heads/3.9-dirty:a2295a4, Dec 21 2021, 22:32:52) \r\n[GCC 4.8.5 20150623 (Red Hat 4.8.5-44)]\r\n\r\n\r\nPreviously working version:\r\nNo config file found, using default configuration\r\npylint 1.7.4, \r\nastroid 1.6.6\r\nPython 3.6.8 (default, Nov 16 2020, 16:55:22) \r\n[GCC 4.8.5 20150623 (Red Hat 4.8.5-44)]\n```\n\n\n### OS / Environment\n\n_No response_\n\n### Additional dependencies\n\n_No response_\n",
    "patch": "diff --git a/pylint/reporters/text.py b/pylint/reporters/text.py\n--- a/pylint/reporters/text.py\n+++ b/pylint/reporters/text.py\n@@ -175,7 +175,7 @@ def on_set_current_module(self, module: str, filepath: str | None) -> None:\n         self._template = template\n \n         # Check to see if all parameters in the template are attributes of the Message\n-        arguments = re.findall(r\"\\{(.+?)(:.*)?\\}\", template)\n+        arguments = re.findall(r\"\\{(\\w+?)(:.*)?\\}\", template)\n         for argument in arguments:\n             if argument[0] not in MESSAGE_FIELDS:\n                 warnings.warn(\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_5667",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about configuration file syntax errors, which is unrelated to the message template parsing problem."
      },
      {
        "idx": 2,
        "id": "similar_4951",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves type checking and operator compatibility, which does not relate to message template parsing."
      },
      {
        "idx": 3,
        "id": "similar_4580",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "This issue is about TOML configuration parsing errors, which is not directly related to message template parsing."
      },
      {
        "idx": 4,
        "id": "similar_4593",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with docstring warnings, which is unrelated to the message template parsing problem."
      },
      {
        "idx": 5,
        "id": "similar_6180",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about a false positive warning related to a decorator, which does not relate to message template parsing."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Add a flag to disable config parsing",
        "issue_body": "### Current problem\r\n\r\nHere's a sample broken `.pylintrc`, placed in the root folder:\r\n\r\n```ini\r\n[pylint]\r\ntest = '%A'\r\n```\r\n\r\nThis is what happens when I try to use pylint now:\r\n```console\r\n$ pylint myfile.py\r\nTraceback (most recent call last):\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/bin/pylint\", line 8, in <module>\r\n    sys.exit(run_pylint())\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/__init__.py\", line 24, in run_pylint\r\n    PylintRun(sys.argv[1:])\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/lint/run.py\", line 324, in __init__\r\n    linter.load_config_file()\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/config/option_manager_mixin.py\", line 319, in load_config_file\r\n    for option, value in parser.items(section):\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 860, in items\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 860, in <listcomp>\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 856, in <lambda>\r\n    value_getter = lambda option: self._interpolation.before_get(self,\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 395, in before_get\r\n    self._interpolate_some(parser, option, L, value, section, defaults, 1)\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 442, in _interpolate_some\r\n    raise InterpolationSyntaxError(\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n\r\n$ pylint --help   \r\nTraceback (most recent call last):\r\n[...]\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n\r\n$ pylint       \r\nTraceback (most recent call last):\r\n[...]\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n```\r\n\r\nIs it possible to add a flag that disables config parsing entirely, so that the pylint isn't completely broken when this happens? `--ignore-config-file` for example?\r\n\r\nP.S. this is a feature I want, and I'd be willing to contribute it.",
        "issue_id": 5667,
        "pr_number": 6351,
        "pr_title": "Add exception handling for broken config files",
        "pr_body": "Extends the error handling of bad config files, to catch even more errors.\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 #5667\r\n",
        "issue_closed_at": "2022-04-15T20:15:52Z",
        "base_commit": "98bb5bf8ebf15fbce960533e5983a71351a1fe3f"
      },
      "summary": "### Summary:\nThis issue is related to the failure of a software tool, pylint, to handle malformed configuration files gracefully. Specifically, the problem arises when a configuration file (.pylintrc) contains improper syntax, such as an incorrect interpolation pattern. The presence of a malformed entry in the configuration file results in pylint throwing an `InterpolationSyntaxError`, which prevents it from executing any further actions, including basic operations like displaying help information or running lint checks.\n\n1. **Problem Description in General Terms**:\n   The main issue is the inability of a software tool to operate when encountering syntax errors in its configuration files. The tool lacks a mechanism to bypass or ignore configuration parsing errors, leading to complete failure in operation.\n\n2. **Key Symptoms and Behaviors Observed**:\n   - Pylint fails to execute and exits with a traceback error.\n   - The error specifically points to a configuration parsing issue, highlighting an interpolation syntax error.\n   - Attempts to run pylint in any capacity (e.g., linting a file, accessing help) result in the same error.\n\n3. **Affected Components or Systems**:\n   - The configuration parsing mechanism of pylint is directly implicated.\n   - The issue affects the overall functionality of pylint as it prevents it from running any of its core features.\n\n4. **Potential Impact or Severity**:\n   - The severity is high for users relying on pylint for code analysis, as a single malformed configuration entry can render the tool unusable.\n   - This can disrupt development workflows and delay code quality checks.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**:\n   - The problem centers around the handling of configuration files using Python's `configparser` module, which requires specific syntax for interpolation patterns.\n   - The proposed solution involves adding a feature (e.g., a command-line flag) that allows users to bypass configuration file parsing, thus enabling the tool to function without being hindered by configuration errors. \n\nThe patch addresses this by modifying the configuration file parsing logic within pylint, potentially adding an option to ignore configuration files and prevent such errors from affecting pylint's usability.",
      "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: Add a flag to disable config parsing\n\nBody:\n### Current problem\r\n\r\nHere's a sample broken `.pylintrc`, placed in the root folder:\r\n\r\n```ini\r\n[pylint]\r\ntest = '%A'\r\n```\r\n\r\nThis is what happens when I try to use pylint now:\r\n```console\r\n$ pylint myfile.py\r\nTraceback (most recent call last):\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/bin/pylint\", line 8, in <module>\r\n    sys.exit(run_pylint())\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/__init__.py\", line 24, in run_pylint\r\n    PylintRun(sys.argv[1:])\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/lint/run.py\", line 324, in __init__\r\n    linter.load_config_file()\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/config/option_manager_mixin.py\", line 319, in load_config_file\r\n    for option, value in parser.items(section):\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 860, in items\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 860, in <listcomp>\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 856, in <lambda>\r\n    value_getter = lambda option: self._interpolation.before_get(self,\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 395, in before_get\r\n    self._interpolate_some(parser, option, L, value, section, defaults, 1)\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 442, in _interpolate_some\r\n    raise InterpolationSyntaxError(\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n\r\n$ pylint --help   \r\nTraceback (most recent call last):\r\n[...]\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n\r\n$ pylint       \r\nTraceback (most recent call last):\r\n[...]\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n```\r\n\r\nIs it possible to add a flag that disables config parsing entirely, so that the pylint isn't completely broken when this happens? `--ignore-config-file` for example?\r\n\r\nP.S. this is a feature I want, and I'd be willing to contribute it.\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/config_file_parser.py\n  function: _ConfigurationFileParser.parse_config_file\n"
    },
    {
      "similar_issue": {
        "issue_title": "DjangoRestFramework: E1131: unsupported operand type(s) for | (unsupported-binary-operation)",
        "issue_body": "### Bug description\r\n\r\n```python\r\n# pylint: disable=missing-docstring\r\n\r\nfrom rest_framework.permissions import BasePermission, IsAuthenticated, SAFE_METHODS\r\n\r\nclass ReadOnly(BasePermission):\r\n    def has_permission(self, request, view):\r\n        return request.method in SAFE_METHODS\r\n\r\npermission_classes = [IsAuthenticated|ReadOnly]\r\n```\r\n\r\n\r\n### Configuration\r\n\r\n_No response_\r\n\r\n### Command used\r\n\r\n```shell\r\npylint binary.py\r\n```\r\n\r\n\r\n### Pylint output\r\n\r\n```shell\r\n************* Module binary\r\nbinary.py:9:22: E1131: unsupported operand type(s) for | (unsupported-binary-operation)\r\n\r\n-----------------------------------\r\nYour code has been rated at 0.00/10\r\n```\r\n\r\n\r\n### Expected behavior\r\n\r\nFor pylint to not throw this error. \r\n\r\nDjango Rest Framework supports binary operands for permissions [1]\r\nThis example code is taken from the documentation [2]\r\n[1] https://github.com/encode/django-rest-framework/blob/master/rest_framework/permissions.py\r\n[2] https://www.django-rest-framework.org/api-guide/permissions/\r\n\r\n### Pylint version\r\n\r\n```shell\r\npylint 2.10.2\r\nastroid 2.7.3\r\nPython 3.9.4 (default, Apr 10 2021,\r\n```\r\n\r\n\r\n### OS / Environment\r\n\r\nDebian GNU/Linux 10 (buster)\r\n\r\n### Additional dependencies\r\n\r\ndjangorestframework==3.12.4\r\n\r\n\r\n*edit*: Added link [2] to django rest frameworks documentation on permissions",
        "issue_id": 4951,
        "pr_number": 6664,
        "pr_title": "Fix ``unsupported-binary-operation`` on classes that overload or",
        "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\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- [ ] Write a good description on what the PR does.\r\n- [ ] If you used multiple emails or multiple names when contributing, add your mails\r\n   and preferred name in ``script/.contributors_aliases.json``\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## Description\r\n\r\nWe have a specific checker looking for people using `|` with two types, apparently on the assumption that anyone doing that is mistakenly trying to use union syntax where it's not supported. This seems to overlook the fact that it is possible for class definitions to use a metaclass that implements `__or__` or `__ror__` as appropriate, which is the case in the permission classes for Django REST Framework, for example.\r\n\r\nCloses #4951\r\n",
        "issue_closed_at": "2022-06-23T05:46:57Z",
        "base_commit": "a4b9ef560166f35f9ecca95d0ec4c82b70fc031f"
      },
      "summary": "### Summary:\n\nThis issue pertains to a compatibility problem between the Django Rest Framework and pylint, a static code analysis tool for Python. The specific problem arises when using the bitwise OR operator (`|`) to combine permission classes, which is a supported feature in Django Rest Framework for defining composite permissions. However, pylint incorrectly identifies this usage as an unsupported binary operation, resulting in an E1131 error. The error message indicates that pylint does not recognize the operand types for the `|` operator in this context, leading to a code quality rating of 0.00/10.\n\nKey symptoms include pylint's inability to parse the Django Rest Framework's idiomatic use of the `|` operator for combining permission classes, which is expected behavior according to Django's documentation. This causes pylint to generate an error message and potentially mislead developers into thinking there is a mistake in their code.\n\nThe affected components include Django Rest Framework's permission handling system and pylint's type checking module. The issue is specific to the interaction between these two systems when analyzing code that uses Django Rest Framework's permission classes.\n\nThe potential impact is primarily on developers using Django Rest Framework who rely on pylint for code quality checks. This issue may lead to confusion and unnecessary debugging efforts, as the error reported by pylint does not reflect an actual problem in the code's logic or functionality.\n\nRelevant technical details include the use of Django Rest Framework version 3.12.4 and pylint version 2.10.2, with the problem manifesting on a Debian GNU/Linux 10 (buster) environment. The solution likely involves updating pylint's type checking logic to correctly interpret the use of the `|` operator with Django Rest Framework's permission classes, as indicated by the changes made in the `pylint/checkers/typecheck.py` file.",
      "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: DjangoRestFramework: E1131: unsupported operand type(s) for | (unsupported-binary-operation)\n\nBody:\n### Bug description\r\n\r\n```python\r\n# pylint: disable=missing-docstring\r\n\r\nfrom rest_framework.permissions import BasePermission, IsAuthenticated, SAFE_METHODS\r\n\r\nclass ReadOnly(BasePermission):\r\n    def has_permission(self, request, view):\r\n        return request.method in SAFE_METHODS\r\n\r\npermission_classes = [IsAuthenticated|ReadOnly]\r\n```\r\n\r\n\r\n### Configuration\r\n\r\n_No response_\r\n\r\n### Command used\r\n\r\n```shell\r\npylint binary.py\r\n```\r\n\r\n\r\n### Pylint output\r\n\r\n```shell\r\n************* Module binary\r\nbinary.py:9:22: E1131: unsupported operand type(s) for | (unsupported-binary-operation)\r\n\r\n-----------------------------------\r\nYour code has been rated at 0.00/10\r\n```\r\n\r\n\r\n### Expected behavior\r\n\r\nFor pylint to not throw this error. \r\n\r\nDjango Rest Framework supports binary operands for permissions [1]\r\nThis example code is taken from the documentation [2]\r\n[1] https://github.com/encode/django-rest-framework/blob/master/rest_framework/permissions.py\r\n[2] https://www.django-rest-framework.org/api-guide/permissions/\r\n\r\n### Pylint version\r\n\r\n```shell\r\npylint 2.10.2\r\nastroid 2.7.3\r\nPython 3.9.4 (default, Apr 10 2021,\r\n```\r\n\r\n\r\n### OS / Environment\r\n\r\nDebian GNU/Linux 10 (buster)\r\n\r\n### Additional dependencies\r\n\r\ndjangorestframework==3.12.4\r\n\r\n\r\n*edit*: Added link [2] to django rest frameworks documentation on permissions\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/typecheck.py\n  line: line 20\n  function: TypeChecker._detect_unsupported_alternative_union_syntax\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:\n\nThis issue is related to a crash in the software tool Pylint when encountering an incorrectly formatted TOML configuration file. The problem arises when users mistakenly configure their TOML files with incorrect table headings or data structures, leading to a Pylint application error. Specifically, the crash occurs due to the software's inability to handle unexpected data types, such as strings where a dictionary is expected, resulting in an 'AttributeError' when Pylint attempts to process configuration options.\n\n1. **Problem description in general terms**: The problem involves Pylint, a tool used for checking the code quality of Python programs, crashing when it processes improperly formatted TOML configuration files. Users may unintentionally use incorrect table headings or data structures within these files, causing Pylint to fail due to unhandled data type mismatches.\n\n2. **Key symptoms and behaviors observed**: When running Pylint with a TOML configuration file that has incorrect table headings or uses mapping configurations instead of the expected format, Pylint crashes with a traceback error. The error message typically involves an 'AttributeError' indicating that a string or a custom object lacks the 'items' or 'find' attribute, which Pylint expects.\n\n3. **Affected components or systems**: The specific components affected by this issue are parts of Pylint's configuration management system, specifically within the `OptionsManagerMixIn` and the TOML parsing logic.\n\n4. **Potential impact or severity**: The impact of this issue is significant for users relying on TOML files for configuring Pylint, particularly if they are unaware of the correct format. It may interrupt development workflows and lead to confusion due to the lack of clear documentation or examples for proper configuration.\n\n5. **Relevant technical details abstracted for broader understanding**: The issue highlights the importance of robust input validation and error handling within software tools. Pylint's configuration parsing mechanisms need to be updated to handle unexpected data types gracefully, providing informative error messages instead of crashing. This involves updating functions responsible for reading and parsing TOML configurations to ensure they can deal with various input scenarios without causing application failures.\n\nThe changes to address the issue involve modifications in the Pylint codebase, specifically within the file `pylint/config/option_manager_mixin.py` in the functions `read_config_file` and `_parse_toml`, as well as in `pylint/lint/pylinter.py` within the function `_load_reporter_by_class`. These updates aim to improve the robustness of the configuration file parsing and error handling processes.",
      "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": "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 pertains to the behavior of the Pylint tool, specifically when using the `docparams` extension to check Python code for documentation compliance. The problem arises when Pylint incorrectly issues a \"useless-type-doc\" warning for parameters that are not documented in the docstring but have type annotations as per PEP 484. \n\n1. **Problem Description**: The Pylint tool generates a warning for parameters with PEP 484 type annotations, suggesting that the type documentation is redundant or unnecessary when it should not. This behavior is inconsistent with the intended functionality of the `docparams` extension, which should only check for the presence or absence of docstrings, not type annotations.\n\n2. **Key Symptoms and Behaviors Observed**: The main symptom is the incorrect issuance of a \"useless-type-doc\" warning by Pylint when analyzing code with the `docparams` extension. The warning is specifically directed at parameters that are not documented in the function's docstring but have type annotations.\n\n3. **Affected Components or Systems**: The components affected by this issue are the Pylint tool, particularly the `docparams` extension module, and any Python codebases that rely on PEP 484 type annotations for parameter type specification.\n\n4. **Potential Impact or Severity**: The impact of this issue is primarily on developer productivity and code quality assessments. It may lead to confusion or misinterpretation of code quality metrics, as well as unnecessary modifications to code to suppress the warning. However, it does not have a direct impact on the execution or functionality of the code itself.\n\n5. **Relevant Technical Details**: The issue is observed in Pylint version 2.8.1 with astroid 2.5.6, running on Python 3.8.3. The warning is triggered by the Pylint `docparams` extension, which should be configured to ignore PEP 484 type annotations and focus solely on the presence of docstrings. The resolution involves changes to the `Docstring.__init__` function in `pylint/extensions/_check_docs_utils.py` and to the `DocstringParameterChecker._compare_ignored_args` function in `pylint/extensions/docparams.py`.",
      "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": "pylint reports false positive error for lru_cache with maxsize omitted",
        "issue_body": "### Bug description\n\nStarting in `v2.13.0` pylint reports warning if you decorate a method with `lru_cache` but do not provide a value for `maxsize` (#5670) . It does this even if you omit a value for `maxsize` and just use `@lru_cache` or `@lru_cache()`.\r\n\r\nThis is incorrect, the `lru_cache` decorator [defaults maxsize to 128 if omitted](https://github.com/python/cpython/blob/main/Lib/functools.py#L479) so it should not warn about this. It should only warn if `maxsize` is explicitly set to `None` by doing `@lru_cache(maxsize=None)` as that is what can create memory leaks.\n\n### Configuration\n\n_No response_\n\n### Command used\n\n```shell\npylint supervisor/host/manager.py\n```\n\n\n### Pylint output\n\n```shell\n************* Module supervisor.host.manager\r\nsupervisor/host/manager.py:71:5: W1516: 'lru_cache' without 'maxsize' will keep all method args alive indefinitely, including 'self' (lru-cache-decorating-method)\n```\n\n\n### Expected behavior\n\nNo warning since we are using the default maxsize of 128.\n\n### Pylint version\n\n```shell\npylint 2.13.4\n```\n\n\n### OS / Environment\n\nmacOS 12.2.1\r\nPython 3.10.2\r\npip 22.0.4\n\n### Additional dependencies\n\n_No response_",
        "issue_id": 6180,
        "pr_number": 6181,
        "pr_title": "Only emit ``lru-cache-decorating-method`` when ``maxsize`` is ``None``",
        "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 #6180.",
        "issue_closed_at": "2022-04-05T14:25:43Z",
        "base_commit": "7a9234f681b3c046b97e4371c84fadcc3ac7c721"
      },
      "summary": "### Summary:\n\nThis issue relates to a false positive warning generated by the `pylint` tool when analyzing Python code. Specifically, it involves the `lru_cache` decorator from Python's `functools` module. The problem occurs when `pylint` version 2.13.0 generates a warning if the `maxsize` parameter is omitted in the `lru_cache` decorator, even though the default behavior of `lru_cache` is to set `maxsize` to 128 when not explicitly specified. The warning is only appropriate if `maxsize` is explicitly set to `None`, which could lead to memory issues. The affected component is the `pylint` tool, particularly its standard library checker module, which incorrectly flags the omission of `maxsize` as a potential issue. The potential impact includes unnecessary warnings for developers using `pylint` to check their code, leading to possible confusion and misallocation of debugging resources. The technical resolution involved updating the `pylint` checker logic to correctly handle the default behavior of `lru_cache`, ensuring warnings are only produced for configurations that can lead to memory leaks. The changes were made in the `pylint` codebase, specifically within the `stdlib.py` and `message_definition_store.py` files.",
      "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 reports false positive error for lru_cache with maxsize omitted\n\nBody:\n### Bug description\n\nStarting in `v2.13.0` pylint reports warning if you decorate a method with `lru_cache` but do not provide a value for `maxsize` (#5670) . It does this even if you omit a value for `maxsize` and just use `@lru_cache` or `@lru_cache()`.\r\n\r\nThis is incorrect, the `lru_cache` decorator [defaults maxsize to 128 if omitted](https://github.com/python/cpython/blob/main/Lib/functools.py#L479) so it should not warn about this. It should only warn if `maxsize` is explicitly set to `None` by doing `@lru_cache(maxsize=None)` as that is what can create memory leaks.\n\n### Configuration\n\n_No response_\n\n### Command used\n\n```shell\npylint supervisor/host/manager.py\n```\n\n\n### Pylint output\n\n```shell\n************* Module supervisor.host.manager\r\nsupervisor/host/manager.py:71:5: W1516: 'lru_cache' without 'maxsize' will keep all method args alive indefinitely, including 'self' (lru-cache-decorating-method)\n```\n\n\n### Expected behavior\n\nNo warning since we are using the default maxsize of 128.\n\n### Pylint version\n\n```shell\npylint 2.13.4\n```\n\n\n### OS / Environment\n\nmacOS 12.2.1\r\nPython 3.10.2\r\npip 22.0.4\n\n### Additional dependencies\n\n_No response_\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/stdlib.py\n  class: StdlibChecker\n  function: StdlibChecker.visit_boolop\n  function: StdlibChecker._check_lru_cache_decorators\n  function: StdlibChecker._check_lru_cache_decorators\n\npylint/message/message_definition_store.py\n  function: MessageDefinitionStore.register_message\n"
    }
  ]
}