All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 00/23] docs: add basic sphinx-domain rST generator to qapidoc
@ 2024-12-13  2:18 John Snow
  2024-12-13  2:18 ` [PATCH 01/23] docs/qapidoc: support header-less freeform sections John Snow
                   ` (23 more replies)
  0 siblings, 24 replies; 59+ messages in thread
From: John Snow @ 2024-12-13  2:18 UTC (permalink / raw)
  To: qemu-devel; +Cc: Peter Maydell, Michael Roth, Markus Armbruster, John Snow

based-on: https://patchew.org/QEMU/20241213011307.2942030-1-jsnow@redhat.com/

Hi!

This series is a very, very barebones implementation for the new QAPI
doc generator. It does not have many features that I presented on at KVM
Forum; the point of this patch set is instead to present a stripped down
basis for ongoing work so we can discuss on-list with full context of
the code available to do so.

The documentation this series generates is *not suitable* for replacing
the current document generator, it has a few glaring omissions - on
purpose - those features have been factored out intentionally so they
can be reviewed with fuller context and more careful review.

What this series does:

- Adds the new "Transmogrifier" rST generator to qapidoc.py, which
  generates an in-memory rST document using qapi-domain directives.
- Adds a test document that showcases this new transmogrifier.

What this series very notably does not do (yet):

- "ifcond" data for anything other than top-level entities is not
  considered or rendered. This means "if" statements for features and
  members are entirely absent.

- The inliner is not present at all. This series renders only
  documentation exactly as it is exists in the source files.

- *branches* are themselves not considered at all; they're skipped
   entirely for now. They will be included alongside the inliner in
   either a subsequent series or a followup to this series.

- Undocumented members and return statements are not autogenerated.

- Pseudofeatures (Things like allow-oob) are not generated as documented
  features.

- Documentation culling: all entities are documented whether or not
  they're relevant to the wire format.

My goal in doing it this way is to save the "fancy" features for later
so we can focus on reviewing and tightening up the core functionality of
the transmogrifier. Once we're on steadier ground, I will re-add the
fanciful features while adjusting the qapi-domain mechanisms. Once
everything looks "roughly right, give or take some minor nits", I will
switch back to the qapi-domain series itself for review before we merge
everything together.

John Snow (23):
  docs/qapidoc: support header-less freeform sections
  qapi/parser: adjust info location for doc body section
  docs/qapidoc: remove example section support
  qapi: expand tags to all doc sections
  qapi/schema: add __repr__ to QAPIDoc.Section
  docs/qapidoc: add transmogrifier stub
  docs/qapidoc: add transmogrifier class stub
  docs/qapidoc: add visit_module() method
  qapi/source: allow multi-line QAPISourceInfo advancing
  docs/qapidoc: add visit_freeform() method
  docs/qapidoc: add preamble() method
  docs/qapidoc: add visit_paragraph() method
  docs/qapidoc: add visit_errors() method
  docs/qapidoc: add format_type() method
  docs/qapidoc: add add_field() and generate_field() helper methods
  docs/qapidoc: add visit_feature() method
  docs/qapidoc: record current documented entity in transmogrifier
  docs/qapidoc: add visit_returns() method
  docs/qapidoc: add visit_member() method
  docs/qapidoc: add visit_sections() method
  docs/qapidoc: add visit_entity()
  docs/qapidoc: implement transmogrify() method
  docs/qapidoc: add transmogrifier test document

 docs/index.rst         |   1 +
 docs/qapi/index.rst    |  53 ++++++
 docs/sphinx/qapidoc.py | 419 ++++++++++++++++++++++++++++++++++++++---
 scripts/qapi/parser.py |  97 +++++++---
 scripts/qapi/source.py |   4 +-
 5 files changed, 524 insertions(+), 50 deletions(-)
 create mode 100644 docs/qapi/index.rst

-- 
2.47.0




^ permalink raw reply	[flat|nested] 59+ messages in thread

end of thread, other threads:[~2025-01-14  9:31 UTC | newest]

Thread overview: 59+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
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
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

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.