{
  "Selected_candidate": {
    "pr_number": 2611,
    "pr_title": "implicit-str-concat-in-sequence: Handling lines with multi-bytes characters - fix #2610",
    "pr_body": "",
    "issue_id": 2610,
    "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_closed_at": "2018-11-26T13:22:07Z",
    "base_commit": "1ac83855b38a8d053ec5d0403a5c0e6e8b191fbb",
    "changes": [
      {
        "file": "pylint/checkers/strings.py",
        "type": "function",
        "name": "process_module",
        "class_name": "StringConstantChecker",
        "code": "def process_module(self, module):\n        self._unicode_literals = \"unicode_literals\" in module.future_imports"
      },
      {
        "file": "pylint/checkers/strings.py",
        "type": "function",
        "name": "check_for_concatenated_strings",
        "class_name": "StringConstantChecker",
        "code": "def check_for_concatenated_strings(self, iterable_node, iterable_type):\n        for elt in iterable_node.elts:\n            if isinstance(elt, Const) and elt.pytype() in _AST_NODE_STR_TYPES:\n                if elt.col_offset < 0:\n                    # This can happen in case of escaped newlines\n                    continue\n                matching_token, next_token = self.string_tokens[\n                    (elt.lineno, elt.col_offset)\n                ]\n                if matching_token != elt.value and next_token is not None:\n                    next_token_type, next_token_pos = next_token[0], next_token[2]\n                    # We do not warn if string concatenation happens over a newline\n                    if (\n                        next_token_type == tokenize.STRING\n                        and next_token_pos[0] == elt.lineno\n                    ):\n                        self.add_message(\n                            \"implicit-str-concat-in-sequence\",\n                            line=elt.lineno,\n                            args=(iterable_type,),\n                        )"
      }
    ]
  },
  "Justification": "Candidate B is most helpful because it addresses a crash occurring in Pylint, similar to the CURRENT bug report where an invalid regex pattern causes an error. Both reports involve issues with unexpected configurations, leading to runtime failures in Pylint. The stack trace provided in Candidate B shares a structural similarity with the CURRENT bug, as both involve critical paths in the Pylint framework that handle configurations and error detection, helping to understand similar failure points. Additionally, both reports relate to the handling of incorrect or incompatible rules, making insights from Candidate B's resolution highly relevant for fixing the CURRENT bug.",
  "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"
}