From: Markus Armbruster <armbru@redhat.com>
To: John Snow <jsnow@redhat.com>
Cc: qemu-devel@nongnu.org, Peter Maydell <peter.maydell@linaro.org>,
Michael Roth <michael.roth@amd.com>
Subject: Re: [PATCH 11/23] docs/qapidoc: add preamble() method
Date: Thu, 09 Jan 2025 11:34:28 +0100 [thread overview]
Message-ID: <87sepss2bv.fsf@pond.sub.org> (raw)
In-Reply-To: <CAFn=p-ZAXSMyO3cWw=CXG1Hbd06ToQeUsgO4FsfNqDEvaZRujg@mail.gmail.com> (John Snow's message of "Wed, 8 Jan 2025 17:58:03 -0500")
John Snow <jsnow@redhat.com> writes:
> On Fri, Dec 20, 2024 at 9:15 AM Markus Armbruster <armbru@redhat.com> wrote:
>
>> John Snow <jsnow@redhat.com> writes:
>>
>> > This method adds the options/preamble to each definition block. Notably,
>> > :since: and :ifcond: are added, as are any "special features" such as
>> > :deprecated: and :unstable:.
>> >
>> > Signed-off-by: John Snow <jsnow@redhat.com>
>> > ---
>> > docs/sphinx/qapidoc.py | 33 ++++++++++++++++++++++++++++++++-
>> > 1 file changed, 32 insertions(+), 1 deletion(-)
>> >
>> > diff --git a/docs/sphinx/qapidoc.py b/docs/sphinx/qapidoc.py
>> > index 6f8f69077b1..85c7ce94564 100644
>> > --- a/docs/sphinx/qapidoc.py
>> > +++ b/docs/sphinx/qapidoc.py
>> > @@ -38,7 +38,7 @@
>> > from qapi.error import QAPIError, QAPISemError
>> > from qapi.gen import QAPISchemaVisitor
>> > from qapi.parser import QAPIDoc
>> > -from qapi.schema import QAPISchema
>> > +from qapi.schema import QAPISchema, QAPISchemaEntity
>> > from qapi.source import QAPISourceInfo
>> >
>> > from sphinx import addnodes
>> > @@ -125,6 +125,37 @@ def ensure_blank_line(self) -> None:
>> > # +2: correct for zero/one index, then increment by one.
>> > self.add_line_raw("", fname, line + 2)
>> >
>> > + # Transmogrification helpers
>> > +
>> > + def preamble(self, ent: QAPISchemaEntity) -> None:
>> > + """
>> > + Generate option lines for qapi entity directives.
>> > + """
>> > + if ent.doc and ent.doc.since:
>> > + assert ent.doc.since.tag == QAPIDoc.Tag.SINCE
>> > + # Generated from the entity's docblock; info location is exact.
>> > + self.add_line(f":since: {ent.doc.since.text}", ent.doc.since.info)
>> > +
>> > + if ent.ifcond.is_present():
>> > + doc = ent.ifcond.docgen()
>> > + # Generated from entity definition; info location is approximate.
>> > + self.add_line(f":ifcond: {doc}", ent.info)
>> > +
>> > + # Hoist special features such as :deprecated: and :unstable:
>> > + # into the options block for the entity. If, in the future, new
>> > + # special features are added, qapi-domain will chirp about
>> > + # unrecognized options and fail.
>> > + for feat in ent.features:
>> > + if feat.is_special():
>> > + # We don't expect special features to have an ifcond property.
>> > + # (Hello, intrepid developer in the future who changed that!)
>> > + # ((With luck, you are not me.))
>> > + assert not feat.ifcond.is_present()
>>
>> Nope :)
>>
>> The attempt to add a conditional special feature now fails with
>>
>> Sphinx parallel build error:
>> AssertionError
>>
>> If you want to outlaw conditional special features, reject them cleanly
>> in schema.py, document the restriction in docs/devel/qapi-code-gen.rst,
>> and explain why in the commit message. Recommend a separate commit, to
>> make it stand out in git-log.
>
> Do you advocate this? I wasn't sure what it *meant* for a special feature
> to be conditional; I couldn't conceive of what it meant to have an ifcond
> for "deprecated" or "unstable", for instance. It sounds like it isn't well
> defined, but we happen to not expressly forbid it.
Semantics are clear enough to me.
"Conditional special feature" combines "conditional feature" (which is a
special case of conditional thing) with special feature (which is a
special case of feature).
The QAPI schema language supports compile-time conditionals for certain
things. Generated code behaves as if the thing didn't exist unless its
condition is true.
QAPI schema features are strings exposed to clients in introspection.
Combine the two: a conditional feature is exposed if and only if its
condition is true.
Existing uses: dynamic-auto-read-only if CONFIG_POSIX, fdset if
CONFIG_BLKIO_VHOST_VDPA_FD.
A special feature is a feature that has special meaning to the
generator, i.e. we generate different code in places when it's present.
Combine: we enable different code for a conditional special feature only
when its condition is true.
No existing uses so far.
Implementation is straightforward, too.
Any code we generate for a conditional thing is guarded by #if
... #endif.
For features, we generate suitable data into qapi-introspect.c.
For special features, we generate a little additional code here and
there; look for .is_special() to find it.
Bug: this additional code lacks #if ... #endif. Simple oversight,
should be easy enough to fix.
> I guard against it here because, similarly, I have no idea how to handle
> the case where it's true.
>
> I didn't realize we technically allow it, though ... would you like me to
> move to expressly forbid it in the parser? (Failing that, I have no idea
> how to display this information otherwise, so I'd need you to sketch
> something out for me; so my inclination is to forbid it as you suggest.
> Future developers can always lift the restriction once they have some
> use-case in mind and a plan for how to display that information.)
I think we should first make a reasonable effort at figuring out how to
handle conditional special features. If we fail, we can add the
restriction instead.
How do you handle features in general, and special features in
particular?
How do you handle conditionals in general?
How do you combine feature and conditional?
How could you combine special feature and conditonal?
[...]
next prev parent reply other threads:[~2025-01-09 10:35 UTC|newest]
Thread overview: 59+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-12-13 2:18 [PATCH 00/23] docs: add basic sphinx-domain rST generator to qapidoc John Snow
2024-12-13 2:18 ` [PATCH 01/23] docs/qapidoc: support header-less freeform sections John Snow
2024-12-16 13:15 ` Markus Armbruster
2025-01-13 19:12 ` John Snow
2025-01-14 9:19 ` Markus Armbruster
2024-12-13 2:18 ` [PATCH 02/23] qapi/parser: adjust info location for doc body section John Snow
2024-12-13 2:18 ` [PATCH 03/23] docs/qapidoc: remove example section support John Snow
2024-12-18 12:27 ` Markus Armbruster
2024-12-18 15:15 ` John Snow
2025-01-09 7:50 ` Markus Armbruster
2024-12-13 2:18 ` [PATCH 04/23] qapi: expand tags to all doc sections John Snow
2024-12-18 10:58 ` Markus Armbruster
2024-12-18 15:14 ` John Snow
2025-01-09 7:51 ` Markus Armbruster
2024-12-20 13:13 ` Markus Armbruster
2025-01-09 18:49 ` John Snow
2025-01-10 7:33 ` Markus Armbruster
2024-12-13 2:18 ` [PATCH 05/23] qapi/schema: add __repr__ to QAPIDoc.Section John Snow
2024-12-13 2:18 ` [PATCH 06/23] docs/qapidoc: add transmogrifier stub John Snow
2024-12-13 2:18 ` [PATCH 07/23] docs/qapidoc: add transmogrifier class stub John Snow
2024-12-13 2:18 ` [PATCH 08/23] docs/qapidoc: add visit_module() method John Snow
2024-12-13 2:18 ` [PATCH 09/23] qapi/source: allow multi-line QAPISourceInfo advancing John Snow
2024-12-20 13:22 ` Markus Armbruster
2025-01-08 21:18 ` John Snow
2025-01-09 8:00 ` Markus Armbruster
2025-01-09 17:19 ` John Snow
2025-01-10 7:37 ` Markus Armbruster
2024-12-13 2:18 ` [PATCH 10/23] docs/qapidoc: add visit_freeform() method John Snow
2024-12-20 13:25 ` Markus Armbruster
2025-01-13 20:14 ` John Snow
2024-12-13 2:18 ` [PATCH 11/23] docs/qapidoc: add preamble() method John Snow
2024-12-20 14:15 ` Markus Armbruster
2025-01-08 22:58 ` John Snow
2025-01-09 10:34 ` Markus Armbruster [this message]
2025-01-09 18:04 ` John Snow
2025-01-10 12:19 ` Markus Armbruster
2025-01-13 20:53 ` John Snow
2025-01-14 9:30 ` Markus Armbruster
2024-12-13 2:18 ` [PATCH 12/23] docs/qapidoc: add visit_paragraph() method John Snow
2024-12-13 2:18 ` [PATCH 13/23] docs/qapidoc: add visit_errors() method John Snow
2024-12-13 2:18 ` [PATCH 14/23] docs/qapidoc: add format_type() method John Snow
2024-12-13 2:18 ` [PATCH 15/23] docs/qapidoc: add add_field() and generate_field() helper methods John Snow
2024-12-13 2:18 ` [PATCH 16/23] docs/qapidoc: add visit_feature() method John Snow
2024-12-20 14:21 ` Markus Armbruster
2025-01-08 22:46 ` John Snow
2024-12-13 2:18 ` [PATCH 17/23] docs/qapidoc: record current documented entity in transmogrifier John Snow
2024-12-20 14:23 ` Markus Armbruster
2025-01-08 21:11 ` John Snow
2025-01-09 10:35 ` Markus Armbruster
2024-12-13 2:18 ` [PATCH 18/23] docs/qapidoc: add visit_returns() method John Snow
2024-12-13 2:18 ` [PATCH 19/23] docs/qapidoc: add visit_member() method John Snow
2024-12-13 2:18 ` [PATCH 20/23] docs/qapidoc: add visit_sections() method John Snow
2024-12-13 2:18 ` [PATCH 21/23] docs/qapidoc: add visit_entity() John Snow
2024-12-13 2:18 ` [PATCH 22/23] docs/qapidoc: implement transmogrify() method John Snow
2024-12-13 2:18 ` [PATCH 23/23] docs/qapidoc: add transmogrifier test document John Snow
2024-12-19 12:31 ` [PATCH 00/23] docs: add basic sphinx-domain rST generator to qapidoc Markus Armbruster
2025-01-08 21:08 ` John Snow
2025-01-09 11:48 ` Markus Armbruster
2025-01-09 17:26 ` John Snow
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87sepss2bv.fsf@pond.sub.org \
--to=armbru@redhat.com \
--cc=jsnow@redhat.com \
--cc=michael.roth@amd.com \
--cc=peter.maydell@linaro.org \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.