{
    "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."
}