-
Notifications
You must be signed in to change notification settings - Fork 403
Description
I have:
- searched the issue tracker for similar issues
- installed the latest version of Quarto CLI
- formatted my issue following the Bug Reports guide
Bug description
In a manuscript project consisting of multiple files that are included in index.qmd, floats (figures, tables) in cross-reference divs are not rendered correctly. The content of the floats themselves are rendered, but not labeled and the caption seems to be included as body text.
If I render the project to HTML, Quarto crashes, but this seems to be a known bug in manuscript projects. Therefore, the examples below will only render to PDF.
Steps to reproduce
1. Create files
_quarto.yml:
project:
type: manuscript
output-dir: _manuscript
output-file: manuscript.pdf
execute:
echo: false
manuscript:
article: index.qmd
format:
# (other formats)
pdf: defaultindex.qmd:
---
title: include-div-mwe
---
## Section
This is a simple placeholder for the manuscript's main document [@knuth84].
This is a figure defined in `index.qmd`: @fig-in-index
::: {#fig-in-index}
```{python}
import matplotlib.pyplot as plt
plt.plot(range(10))
```
A plot in a div float in `index.qmd`
:::
This is a figure defined in `include.qmd`: @fig-in-include
{{< include include.qmd >}}include.qmd:
::: {#fig-in-include}
```{python}
import matplotlib.pyplot as plt
plt.plot(range(9, -1, -1))
```
A plot in a div float in `include.qmd`
:::2. Render
quarto render3. Control experiment: add configuration for default project type
_quarto-default.yml:
project:
type: default
render:
- index.qmd
output-dir: _default
output-file: default.pdf
execute:
echo: false
format:
pdf: default4. Render as default project
quarto render --profile defaultHere is a zip of my example, which you can run using Python (optionally through uv):
Actual behavior
When rendering the manuscript project:
See manuscript.pdf. Both plots are included in the document. Both captions are not prefixed with the figure label. The label of Figure 1 is located at the end of the document and correctly cross-referenced. The label of Figure 2 is not rendered and cannot be referenced.
The output of quarto render shows a warning:
WARNING (C:/Users/chaasjes/Downloads/include-div-mwe/.venv/Lib/site-packages/quarto_cli/share/filters/main.lua:22344) FloatRefTarget with no content: fig-in-include
When rendering the default project:
See default.pdf. Both plots are included with correctly labeled and cross-referenced captions. There are no warnings or errors in the output.
Other interesting details:
The same behavior is seen when an image is used instead of an executable code block.
If multiple images are included, with different figure labels, the manuscript project puts the separate images in subfigures.
Expected behavior
Regardless of the project type, the output PDF file contains two figures with captions labeled as Figure 1 and Figure 2, and cross references in the text are rendered correctly. In other words, the output should be the same for the manuscript and default projects.
Your environment
- IDE: VSCode 1.108.2
- OS: Windows 11
Quarto check output
Quarto 1.8.27
[>] Checking environment information...
Quarto cache location: [REDACTED]\AppData\Local\quarto
[>] Checking versions of quarto binary dependencies...
Pandoc version 3.6.3: OK
Dart Sass version 1.87.0: OK
Deno version 2.3.1: OK
Typst version 0.13.0: OK
[>] Checking versions of quarto dependencies......OK
[>] Checking Quarto installation......OK
Version: 1.8.27
Path: [REDACTED]\.venv\Lib\site-packages\quarto_cli\bin
CodePage: 1252
[>] Checking tools....................OK
TinyTeX: v2025.07
Chromium: (not installed)
[>] Checking LaTeX....................OK
Using: TinyTex
Path: [REDACTED]\AppData\Roaming\TinyTeX\bin\windows\
Version: 2025
[>] Checking Chrome Headless....................OK
Using: Chrome found on system
Path: C:\Program Files (x86)\Microsoft\Edge\Application\msedge.exe
Source: Windows Registry
[>] Checking basic markdown render....OK
[>] Checking Python 3 installation....OK
Version: 3.13.1
Path: [REDACTED]/.venv/Scripts/python.exe
Jupyter: 5.9.1
Kernels: python3
[>] Checking Jupyter engine render....OK
[>] Checking R installation...........(None)
Unable to locate an installed version of R.
Install R from https://cloud.r-project.org/