[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH 01/23] docs/qapidoc: support header-less freeform sections
From: |
Markus Armbruster |
Subject: |
Re: [PATCH 01/23] docs/qapidoc: support header-less freeform sections |
Date: |
Mon, 16 Dec 2024 14:15:06 +0100 |
User-agent: |
Gnus/5.13 (Gnus v5.13) |
John Snow <jsnow@redhat.com> writes:
> The code as written can't handle if a header isn't found, because `node`
> will be uninitialized.
Yes, we initialize @node only if we have a heading.
Made me wonder what happens when we don't. So I deleted the = from the
"# = Subsection" line in doc-good.json, and got:
Exception occurred:
File "/work/armbru/qemu/docs/sphinx/qapidoc.py", line 425, in freeform
self._parse_text_into_node(text, node)
^^^^
UnboundLocalError: cannot access local variable 'node' where it is not
associated with a value
So you're fixing a crash bug, but that's perhaps less than clear from
the commit message.
> If we don't have a section title, create a
> generic block to insert text into instead.
>
> This patch removes a lingering pylint warning in the QAPIDoc implementation
Can you show me the warning? My pylint doesn't...
> that prevents getting a clean baseline to use for forthcoming
> additions.
>
> I am not attempting to *fully* clean up the existing QAPIDoc
> implementation in pylint because I intend to delete it anyway; this
> patch merely accomplishes a baseline under a specific pylint
> configuration:
>
> PYTHONPATH=../../scripts/ pylint --disable=fixme,too-many-lines,\
> consider-using-f-string,missing-docstring,unused-argument,\
> too-many-arguments,too-many-positional-arguments,\
> too-many-public-methods \
> qapidoc.py
What version of pylint? Mine chokes on too-many-positional-arguments.
> This at least ensures there aren't regressions outside of these general
> warnings in the new qapidoc.py code to be committed.
>
> Signed-off-by: John Snow <jsnow@redhat.com>
> ---
> docs/sphinx/qapidoc.py | 2 ++
> 1 file changed, 2 insertions(+)
>
> diff --git a/docs/sphinx/qapidoc.py b/docs/sphinx/qapidoc.py
> index 5f96b46270b..5a4d7388b29 100644
> --- a/docs/sphinx/qapidoc.py
> +++ b/docs/sphinx/qapidoc.py
> @@ -421,6 +421,8 @@ def freeform(self, doc):
> node = self._start_new_heading(heading, len(leader))
> if text == '':
> return
> + else:
> + node = nodes.container()
>
> self._parse_text_into_node(text, node)
> self._cur_doc = None
Plausible enough (and I acked a similar fix previously, commit
2664f3176a8), but I'm a Sphinx ignoramus :)
- [PATCH 00/23] docs: add basic sphinx-domain rST generator to qapidoc, John Snow, 2024/12/12
- [PATCH 01/23] docs/qapidoc: support header-less freeform sections, John Snow, 2024/12/12
- Re: [PATCH 01/23] docs/qapidoc: support header-less freeform sections,
Markus Armbruster <=
- [PATCH 03/23] docs/qapidoc: remove example section support, John Snow, 2024/12/12
- [PATCH 02/23] qapi/parser: adjust info location for doc body section, John Snow, 2024/12/12
- [PATCH 04/23] qapi: expand tags to all doc sections, John Snow, 2024/12/12
- [PATCH 05/23] qapi/schema: add __repr__ to QAPIDoc.Section, John Snow, 2024/12/12
- [PATCH 06/23] docs/qapidoc: add transmogrifier stub, John Snow, 2024/12/12