{
  "Selected_candidate": {
    "pr_number": 8076,
    "pr_title": "Fix #6914: figure numbers are unexpectedly assigned to uncaptioned items",
    "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- refs: #6914 \r\n- The figure numbers should be assigned to items only having captions or\r\ntitles.  This uses `get_numfig_title()` to ensures it on assign numbers.\r\n",
    "issue_id": 6914,
    "issue_title": "References to figures without captions: errors in both HTML and LaTeX",
    "issue_body": "\r\n**Describe the bug**\r\nUsing figures without captions causes errors in both HTML (though these are properly reported when source is processed) and in LaTeX (they are not reported until LaTeX says there were undefined references).\r\n\r\nThis was the test document, compiled with sphinx 2.2.2 from pypi; `numfig=True` was added to conf.py, the project was otherwise generated with sphinx-build with no other changes. It is attached here: [sphinx-captions.zip](https://github.com/sphinx-doc/sphinx/files/3947135/sphinx-captions.zip)\r\n\r\n```\r\nWelcome to foo's documentation!\r\n===============================\r\n\r\nReferences:\r\n\r\n* figure without caption\r\n\r\n   * plain reference :ref:`fig-sample-nocaption` (error: HTML, LaTeX)\r\n   * named reference :ref:`figure without caption <fig-sample-nocaption>` (error: LaTeX)\r\n   * numbered reference :numref:`fig-sample-nocaption` (error: LaTeX)\r\n\r\n* figure with caption\r\n\r\n   * plain reference :ref:`fig-sample-caption`\r\n   * named reference :ref:`figure without caption <fig-sample-caption>`\r\n   * numbered reference :numref:`fig-sample-caption`\r\n\r\n.. _fig-sample-nocaption:\r\n.. figure:: sample.png\r\n\r\n\r\n.. _fig-sample-caption:\r\n.. figure:: sample.png\r\n   \r\n   This is some caption.\r\n```\r\n\r\nand these are the results:\r\n\r\n1. misleading warning: **index.rst:8: WARNING: undefined label: fig-sample-nocaption (if the link has no caption the label must precede a section header)**\r\n2. this is HTML output (the error highlighted corresponds to the warning mentioned above):\r\n![html output](https://user-images.githubusercontent.com/1029876/70568432-2b150c00-1b98-11ea-98ac-67e7fbc23927.png)\r\n3. this is LaTeX (pdflatex) output:\r\n```\r\nLaTeX Warning: Hyper reference `index:fig-sample-nocaption' on page 1 undefined\r\n on input line 99.\r\nLaTeX Warning: Hyper reference `index:fig-sample-nocaption' on page 1 undefined\r\n on input line 102.\r\n```\r\n![latex output](https://user-images.githubusercontent.com/1029876/70568602-7fb88700-1b98-11ea-85bd-b7b6fec93e41.png)\r\n\r\n**Expected behavior**\r\nI expect\r\n1. sphinx to produce valid LaTeX input without undefined references;\r\n2. uncaptioned figures to be referencable in LaTeX (this could be an optional setting perhaps causing uncaptioned figured to produce only \"Figure 4.1.\" caption);\r\n3. warning about figure not being captioned to be more meaningful -- I understand that non-numbered figure cannot be referenced via :ref:`label` (as the label will not resolve to any text) but the warning is not pointing to how to fix the issue.\r\n\r\n**Environment info**\r\n- OS: Ubuntu 18.04 LTS\r\n- Python version: 3.6.8\r\n- Sphinx version: 2.2.2\r\n- Sphinx extensions: none\r\n- Extra tools: pdflatex TeXLive\r\n",
    "issue_closed_at": "2020-11-03T02:29:07Z",
    "base_commit": "b4add96a53f30d0e901fa683a8d9e698240e8fe0",
    "changes": [
      {
        "file": "sphinx/environment/collectors/toctree.py",
        "type": "function",
        "name": "assign_figure_numbers",
        "class_name": "TocTreeCollector",
        "code": "def assign_figure_numbers(self, env: BuildEnvironment) -> List[str]:\n        \"\"\"Assign a figure number to each figure under a numbered toctree.\"\"\"\n\n        rewrite_needed = []\n\n        assigned = set()  # type: Set[str]\n        old_fignumbers = env.toc_fignumbers\n        env.toc_fignumbers = {}\n        fignum_counter = {}  # type: Dict[str, Dict[Tuple[int, ...], int]]\n\n        def get_figtype(node: Node) -> str:\n            for domain in env.domains.values():\n                figtype = domain.get_enumerable_node_type(node)\n                if figtype:\n                    return figtype\n\n            return None\n\n        def get_section_number(docname: str, section: nodes.section) -> Tuple[int, ...]:\n            anchorname = '#' + section['ids'][0]\n            secnumbers = env.toc_secnumbers.get(docname, {})\n            if anchorname in secnumbers:\n                secnum = secnumbers.get(anchorname)\n            else:\n                secnum = secnumbers.get('')\n\n            return secnum or tuple()\n\n        def get_next_fignumber(figtype: str, secnum: Tuple[int, ...]) -> Tuple[int, ...]:\n            counter = fignum_counter.setdefault(figtype, {})\n\n            secnum = secnum[:env.config.numfig_secnum_depth]\n            counter[secnum] = counter.get(secnum, 0) + 1\n            return secnum + (counter[secnum],)\n\n        def register_fignumber(docname: str, secnum: Tuple[int, ...],\n                               figtype: str, fignode: Element) -> None:\n            env.toc_fignumbers.setdefault(docname, {})\n            fignumbers = env.toc_fignumbers[docname].setdefault(figtype, {})\n            figure_id = fignode['ids'][0]\n\n            fignumbers[figure_id] = get_next_fignumber(figtype, secnum)\n\n        def _walk_doctree(docname: str, doctree: Element, secnum: Tuple[int, ...]) -> None:\n            for subnode in doctree.children:\n                if isinstance(subnode, nodes.section):\n                    next_secnum = get_section_number(docname, subnode)\n                    if next_secnum:\n                        _walk_doctree(docname, subnode, next_secnum)\n                    else:\n                        _walk_doctree(docname, subnode, secnum)\n                elif isinstance(subnode, addnodes.toctree):\n                    for title, subdocname in subnode['entries']:\n                        if url_re.match(subdocname) or subdocname == 'self':\n                            # don't mess with those\n                            continue\n\n                        _walk_doc(subdocname, secnum)\n                elif isinstance(subnode, nodes.Element):\n                    figtype = get_figtype(subnode)\n                    if figtype and subnode['ids']:\n                        register_fignumber(docname, secnum, figtype, subnode)\n\n                    _walk_doctree(docname, subnode, secnum)\n\n        def _walk_doc(docname: str, secnum: Tuple[int, ...]) -> None:\n            if docname not in assigned:\n                assigned.add(docname)\n                doctree = env.get_doctree(docname)\n                _walk_doctree(docname, doctree, secnum)\n\n        if env.config.numfig:\n            _walk_doc(env.config.master_doc, tuple())\n            for docname, fignums in env.toc_fignumbers.items():\n                if fignums != old_fignumbers.get(docname):\n                    rewrite_needed.append(docname)\n\n        return rewrite_needed"
      }
    ]
  },
  "Justification": "Candidate A is the most helpful because it directly involves the use of references (both numbered and unnumbered) within documentation built using Sphinx, which is very similar to the \"no number is assigned for table\" warning in the CURRENT bug report. Both cases relate to undefined references in documentation generated by Sphinx. Given that both reports discuss the intricacies of referencing figures and tables in LaTeX and HTML outputs, the insights into the irrelevant warnings provided in Candidate A could guide debugging in the context of the number assignment warnings seen in the CURRENT report. The patch associated with Candidate A also tackles the assignment of numbers to items without captions, aligning with the logical structure of the CURRENT issue regarding number assignments.",
  "instance_id": "sphinx-doc__sphinx-8474",
  "repo": "sphinx-doc/sphinx",
  "created_at": "2020-11-22T16:24:25Z",
  "problem_statement": "v3.3 upgrade started generating \"WARNING: no number is assigned for table\" warnings\nWe've updated to Sphinx 3.3 in our documentation, and suddenly the following warning started popping up in our builds when we build either `singlehtml` or `latex`.:\r\n\r\n`WARNING: no number is assigned for table:`\r\n\r\nI looked through the changelog but it didn't seem like there was anything related to `numref` that was changed, but perhaps I missed something? Could anyone point me to a change in the numref logic so I can figure out where these warnings are coming from?\n",
  "patch": "diff --git a/sphinx/domains/std.py b/sphinx/domains/std.py\n--- a/sphinx/domains/std.py\n+++ b/sphinx/domains/std.py\n@@ -852,8 +852,9 @@ def _resolve_numref_xref(self, env: \"BuildEnvironment\", fromdocname: str,\n             if fignumber is None:\n                 return contnode\n         except ValueError:\n-            logger.warning(__(\"no number is assigned for %s: %s\"), figtype, labelid,\n-                           location=node)\n+            logger.warning(__(\"Failed to create a cross reference. Any number is not \"\n+                              \"assigned: %s\"),\n+                           labelid, location=node)\n             return contnode\n \n         try:\n"
}