[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20250924115543.49433321@foz.lan>
Date: Wed, 24 Sep 2025 11:55:43 +0200
From: Mauro Carvalho Chehab <mchehab+huawei@...nel.org>
To: Akira Yokosawa <akiyks@...il.com>
Cc: linux-kernel@...r.kernel.org, Linux Doc Mailing List
<linux-doc@...r.kernel.org>, Jonathan Corbet <corbet@....net>
Subject: Re: [PATCH 0/1] sphinx-build-wrapper: add support for skipping
sphinx-build
Em Wed, 24 Sep 2025 16:03:59 +0900
Akira Yokosawa <akiyks@...il.com> escreveu:
> On Mon, 22 Sep 2025 14:23:30 +0200, Mauro Carvalho Chehab wrote:
> > Em Mon, 22 Sep 2025 20:30:40 +0900
> > Akira Yokosawa <akiyks@...il.com> escreveu:
> >
> >> On Sun, 21 Sep 2025 11:13:24 +0200, Mauro Carvalho Chehab wrote:
> >>> Hi Jon,
> >>>
> >>> This patch adds support for not running sphinx-build at the wrapper
> >>> tool. It was requested by Akira, who wanted to be able to ignore
> >>> Sphinx errors during latex build and still try to build PDF.
> >>
> >> Thank you for trying to figure out my intention.
> >> However, you failed to see the point.
> >>
> >>>
> >>> This patch is against docs/build-script and applies after the 3 patch
> >>> series I sent yesterday:
> >>>
> >>> https://lore.kernel.org/linux-doc/cover.1758361087.git.mchehab+huawei@kernel.org/
> >>>
> >>>
> >>> While Akira's original intention is to have pdfdocs target depend on
> >>> latexdocs, IMO, this is overkill, as probably only Akira and a couple
> >>> of other developers might want to have such behavior.
> >>
> >> I think it is only you who don't want such behavior.
> >
> > Whom else wants to use "make -i" to skip failed latexdocs build and
> > still do pdf builds? For what reason?
>
> Hmm, looks like you were suffered from context mismatch.
>
> My message you tried to understand (archived at:
>
> https://lore.kernel.org/5031e0c4-f17e-41b8-8955-959989e797f2@gmail.com/
>
> ) started this way:
>
> Hi, (just got v8, but sending anyway ...),
>
> , and the message assumed the "make pdfdocs" behavior of v7.
>
> At the time, I thought it was what you had intended and it looked as though
> you wanted latexmk/xelatex to continue running as much as possible ignoring
> any intermediate errors.
No, this was a bug, as I answered you already and sent the fix:
if sphinx-build fails, the script shall bail out.
> You have since fixed the missed exception handling at the latexdocs phase,
> but your rapid respins of this series simply overwhelmed me and I have
> failed to see "make pdfdocs" now gives up at latexdocs error.
>
> My intention of mentioning GNU Make's options of -i, -k, etc. in the message
> was to show you that the make--sub-make scheme is so flexible and it can
> even emulate the buggy behavior of then sphinx-build-wrapper.
>
> In normal cases, I won't use any of those options.
> But as a human developer, I sometimes use them when I observe build errors
> somewhere in "make pdfdocs".
...
> >> All I want is to restore the current behavior, without any need to
> >> use such an ad-hoc script.
> >
> > Huh?
> >
> > You said you want to be able to do just the reverse: to ignore
> > failures at latex build ("make -i").
>
> No, as I said above, I don't want it in most cases.
> But in rare occasions, I might want it. That depends on the situation
> at hand.
There is exactly the usecase where running directly via makefile
may not be enough, as you may want to play with different scenarios.
On such cases, you'll be better served by calling the script directly,
as it provides more flexibility without requiring to pass parameters via
env vars nor nor enable/disable different venvs to test with different
versions of docutils/spinx packages.
On an hypothetical scenario where pdfdocs is not working fine, calling
the script directly allows to easily test different scenarios, and it is
faster, as you won't do anything else but running directly the doc build
logic:
# equivalent to "make pdfdocs":
# build tex. If sphinx-build succeeds, build pdf for each tex
./tools/docs/sphinx-build-wrapper pdfdocs
# equivalent to "make latexdocs"
./tools/docs/sphinx-build-wrapper latexdocs
# generate latex with Sphinx 3.4.3 in verbose mode
# equivalent to:
# . Sphinx_3.4.3/bin/activate
# make V=1 latexdocs
# deactivate
./tools/docs/sphinx-build-wrapper latexdocs -V Sphinx_3.4.3 -v
# build only translations.tex with Sphinx 5.2.0 in verbose mode
./tools/docs/sphinx-build-wrapper latexdocs -V Sphinx_5.2.0 -v --sphinxdirs translations
Once you're happy with the above, you could proceed with the pdf build step,
forcing the script to skip sphinx-build step with:
# Run just PDF build step, producing a summary at the end
$ ./tools/docs/sphinx-build-wrapper pdfdocs -s -v
...
Summary
=======
...
translations/pdf/translations.pdf: FAILED
...
# After building latexdocs for translations.tex and core-api.tex
# run the run test PDF build, producing a single line
# with all failures for each generated .tex file:
$ ./tools/docs/sphinx-build-wrapper pdfdocs -s --sphinxdirs translations core-api
...
Error: Can't build 1 PDF file(s): translations/pdf/translations.pdf
# Use a different variable font deny configuration directory
$ ./tools/docs/sphinx-build-wrapper pdfdocs -s --sphinxdirs translations --deny-vf ~/new-deny-vf/
> >> Furthermore, your "cleanup" is obfuscating the very fact that "pdfdocs"
> >> needs a successful "latexdocs" stage.
> >>
> >> I believe Documentation/Makefile is the right place to describe it.
> >
> > If you want to propose such change, be my guest. As I said, *I* won't propose
> > it, as IMO it is a bad idea, but if you want, feel free to submit a patch
> > after this one similar to:
> >
> > -htmldocs mandocs infodocs texinfodocs latexdocs epubdocs xmldocs pdfdocs linkcheckdocs:
> > +htmldocs mandocs infodocs texinfodocs latexdocs epubdocs xmldocs linkcheckdocs:
> > +
> > +pdfdocs: latexdocs
> > + +$(Q)$(PYTHON3) $(BUILD_WRAPPER) $@ -s \
> > + --sphinxdirs="$(SPHINXDIRS)" \
> > + --builddir="$(BUILDDIR)" --deny-vf=$(FONTS_CONF_DENY_VF) \
> > + --paper=$(PAPER)
> >
> > and let's discuss its pros/cons in separate.
>
> OK. This looks like the way forward to me.
>
> I'll prepare a patch (set) and submit it after v6.18-rc1.
Ok, but as I said, IMO we're better served running the script
directly while debugging issues.
> In the meantime, I think we might be better off if we could root-cause
> the "latexmk bug" you repeatedly claimed you had observed, without providing
> any steps to reproduce.
This is on my todo list.
With regards to the steps to reproduce you need to remove this from make:
|| sh $(srctree)/scripts/check-variable-fonts.sh || exit
to ensure that errors will be handled by make.
As we depend on error handling logic, it means that you may need to build docs
with different configurations, different types of latex errors produced by
sphinx-build, and test with different versions of docutils, sphinx, xelatex and
latexmk, and hope to have a .tex file that has errors but still generate .pdf.
Getting such issues is time consuming and it needs a certain amount of luck
to catch it, as you depend on changes at the *.rst files that will produce
a .tex file with the exact amount of spicy to produce such behavior.
With me, it only happens when I don't want it to happen ;-)
-
Another option would be to try to manually generate a defective *.tex file
that doesn't produce a critical error but still generates a.pdf output when
xelatex is called by hand.
Anyway, this requires a calm week where you don't have anything else
to do, and you're prepared to waste several hours trying to pick the
hot spot on away that it would be reproducible by others.
So, this has low priority.
> Let me continue in another thread.
> It would be far more interesting for me to (try to) figure out what you
> had observed.
>
> Thanks,
> Akira
>
Thanks,
Mauro
Powered by blists - more mailing lists