Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Confusing Location for Files Written from `@example Blocks #2617

Open
MarkNahabedian opened this issue Jan 16, 2025 · 0 comments
Open

Confusing Location for Files Written from `@example Blocks #2617

MarkNahabedian opened this issue Jan 16, 2025 · 0 comments

Comments

@MarkNahabedian
Copy link
Contributor

In some of my documentation pages, I have examples that generate SVG images. I use XML.jl to generate the SVG and write it to a file. This is done in an @example block and then @raw htmlis used to add the image to the doc page.

This might relate somewhat to #2533. It's not clear in the example that resolves that issue how to do this in an md file rather than a jl file. In any case, I would prefer my SVG files be incorporated by reference, arther than in-lined.

My markdown files contain examples like

```@example sine-wave-example
using RoseEngine
rotor = Rotor(3, 1//2, 1//8, sine_wave)
render_rotors(joinpath(@__DIR__, "sine-wave-example.svg"),
              rotor,
              1//256; debug=true)
```

```@raw html
<img src="sine-wave-example.svg"
     width="50%"/>
```

These are in a file named docs/src/check_wave_amplitudes.md, which is inclused in the documentation via the pages block

    pages=[
    "Home" => "index.md",
    "Check Wave Amplitudes" => "check_wave_amplitudes.md"
],

When I build my documentation locally, the img.src links for my SVG files are broken. This is because the SVG files are written to docs/build while the generated HTML file that refers to them is written to docs/build/check_wave_amplitudes.

If Documenter is going to create a separate directory for each of the items in the pages clause, shouldn't that directory be the working directory when any example code for that page is run?

The current behavior is confusing and requires documentation authors to kludge the link references for their documentation to render properly.

I fear this might be a breaking change unless some possibly questionable and fragile cleverness is applied though.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant