{
    "Selected_candidate": {
        "pr_number": 5521,
        "pr_title": "Fix #5493: gettext: crashed with broken template",
        "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- refs: #5493 \r\n",
        "issue_id": 5493,
        "issue_title": "Encountered unknown tag 'end'",
        "issue_body": "### Problem\r\nFile \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/parser.py\", line 59, in fail\r\n    raise exc(msg, lineno, self.name, self.filename)\r\njinja2.exceptions.TemplateSyntaxError: Encountered unknown tag 'end'. Jinja was looking for the following tags: 'endfor' or 'else'. The innermost block that needs to be closed is 'for'.\r\n\r\n#### Procedure to reproduce the problem\r\n```\r\nmake gettext\r\n```\r\n\r\n#### Error logs / results\r\n```\r\n# Sphinx version: 1.8.1\r\n# Python version: 3.6.0 (CPython)\r\n# Docutils version: 0.14 \r\n# Jinja2 version: 2.10\r\n# Last messages:\r\n#   读取模板……[  4%] /Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/alabaster/donate.html\r\n#   \r\n#   读取模板……[  6%] /Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/alabaster/layout.html\r\n#   \r\n#   读取模板……[  8%] /Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/alabaster/navigation.html\r\n#   \r\n#   读取模板……[ 10%] /Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/alabaster/relations.html\r\n#   \r\n#   读取模板……[ 13%] /Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/matplotlib/backends/web_backend/all_figures.html\r\n#   \r\n# Loaded extensions:\r\n#   sphinx.ext.mathjax (1.8.1) from /Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/sphinx/ext/mathjax.py\r\n#   alabaster (0.7.11) from /Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/alabaster/__init__.py\r\nTraceback (most recent call last):\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/sphinx/cmd/build.py\", line 304, in build_main\r\n    app.build(args.force_all, filenames)\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/sphinx/application.py\", line 341, in build\r\n    self.builder.build_update()\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/sphinx/builders/__init__.py\", line 347, in build_update\r\n    len(to_build))\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/sphinx/builders/gettext.py\", line 258, in build\r\n    self._extract_from_template()\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/sphinx/builders/gettext.py\", line 252, in _extract_from_template\r\n    for line, meth, msg in extract_translations(context):\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/ext.py\", line 214, in _extract\r\n    source = self.environment.parse(source)\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/environment.py\", line 493, in parse\r\n    self.handle_exception(exc_info, source_hint=source)\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/environment.py\", line 780, in handle_exception\r\n    reraise(exc_type, exc_value, tb)\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/_compat.py\", line 37, in reraise\r\n    raise value.with_traceback(tb)\r\n  File \"<unknown>\", line 31, in template\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/environment.py\", line 497, in _parse\r\n    return Parser(self, source, name, encode_filename(filename)).parse()\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/parser.py\", line 901, in parse\r\n    result = nodes.Template(self.subparse(), lineno=1)\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/parser.py\", line 883, in subparse\r\n    rv = self.parse_statement()\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/parser.py\", line 130, in parse_statement\r\n    return getattr(self, 'parse_' + self.stream.current.value)()\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/parser.py\", line 199, in parse_for\r\n    body = self.parse_statements(('name:endfor', 'name:else'))\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/parser.py\", line 165, in parse_statements\r\n    result = self.subparse(end_tokens)\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/parser.py\", line 883, in subparse\r\n    rv = self.parse_statement()\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/parser.py\", line 144, in parse_statement\r\n    self.fail_unknown_tag(token.value, token.lineno)\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/parser.py\", line 97, in fail_unknown_tag\r\n    return self._fail_ut_eof(name, self._end_token_stack, lineno)\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/parser.py\", line 90, in _fail_ut_eof\r\n    self.fail(' '.join(message), lineno)\r\n  File \"/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/jinja2/parser.py\", line 59, in fail\r\n    raise exc(msg, lineno, self.name, self.filename)\r\njinja2.exceptions.TemplateSyntaxError: Encountered unknown tag 'end'. Jinja was looking for the following tags: 'endfor' or 'else'. The innermost block that needs to be closed is 'for'.\r\n```\r\n\r\n### Environment info\r\n- OS: Mac\r\n- Python version: 3.6.0 (CPython)\r\n- Sphinx version: 1.8.1\r\n",
        "issue_closed_at": "2018-10-12T13:38:02Z",
        "base_commit": "551ce9e759e6fc28d1631a12401955dcb15679ba",
        "changes": [
            {
                "file": "sphinx/builders/gettext.py",
                "type": "line",
                "name": "line 22",
                "code": "\nfrom sphinx.builders import Builder\nfrom sphinx.domains.python import pairindextypes\nfrom sphinx.locale import __\nfrom sphinx.util import split_index_msg, logging, status_iterator\nfrom sphinx.util.console import bold  # type: ignore"
            },
            {
                "file": "sphinx/builders/gettext.py",
                "type": "function",
                "name": "_extract_from_template",
                "class_name": "MessageCatalogBuilder",
                "code": "def _extract_from_template(self):\n        # type: () -> None\n        files = list(self._collect_templates())\n        files.sort()\n        logger.info(bold(__('building [%s]: ') % self.name), nonl=1)\n        logger.info(__('targets for %d template files'), len(files))\n\n        extract_translations = self.templates.environment.extract_translations\n\n        for template in status_iterator(files, __('reading templates... '), \"purple\",  # type: ignore  # NOQA\n                                        len(files), self.app.verbosity):\n            with open(template, 'r', encoding='utf-8') as f:  # type: ignore\n                context = f.read()\n            for line, meth, msg in extract_translations(context):\n                origin = MsgOrigin(template, line)\n                self.catalogs['sphinx'].add(msg, origin)"
            }
        ]
    },
    "Justification": "Candidate B addresses template failures which directly relate to the current issue of incorrect member listing in generated outputs. The shared components of Jinja2 parsing and potential similar failures in how members are processed in templates will likely provide valuable insights. Understanding the errors and fixes in Candidate B could illuminate potential issues with handling the `members` variable in the CURRENT bug, making it particularly helpful."
}