mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-07-27 04:13:53 -06:00
docs/qapidoc: add visit_sections() method
Implement the actual main dispatch method that processes and handles the list of doc sections for a given QAPI entity. Process doc sections in strict source order. This is good; reordering doc text is undesirable. Improvement over the old doc generator, which can reorder doc comments that don't adhere to (largely unspoken) conventions. Signed-off-by: John Snow <jsnow@redhat.com> Message-ID: <20250311034303.75779-53-jsnow@redhat.com> Acked-by: Markus Armbruster <armbru@redhat.com> [Commit message extended] Signed-off-by: Markus Armbruster <armbru@redhat.com>
This commit is contained in:
parent
dbf51d15fd
commit
8cb0a41490
1 changed files with 25 additions and 0 deletions
|
@ -288,6 +288,31 @@ class Transmogrifier:
|
|||
|
||||
self.ensure_blank_line()
|
||||
|
||||
def visit_sections(self, ent: QAPISchemaDefinition) -> None:
|
||||
sections = ent.doc.all_sections if ent.doc else []
|
||||
|
||||
# Add sections in source order:
|
||||
for section in sections:
|
||||
if section.kind == QAPIDoc.Kind.PLAIN:
|
||||
self.visit_paragraph(section)
|
||||
elif section.kind == QAPIDoc.Kind.MEMBER:
|
||||
assert isinstance(section, QAPIDoc.ArgSection)
|
||||
self.visit_member(section)
|
||||
elif section.kind == QAPIDoc.Kind.FEATURE:
|
||||
assert isinstance(section, QAPIDoc.ArgSection)
|
||||
self.visit_feature(section)
|
||||
elif section.kind in (QAPIDoc.Kind.SINCE, QAPIDoc.Kind.TODO):
|
||||
# Since is handled in preamble, TODO is skipped intentionally.
|
||||
pass
|
||||
elif section.kind == QAPIDoc.Kind.RETURNS:
|
||||
self.visit_returns(section)
|
||||
elif section.kind == QAPIDoc.Kind.ERRORS:
|
||||
self.visit_errors(section)
|
||||
else:
|
||||
assert False
|
||||
|
||||
self.ensure_blank_line()
|
||||
|
||||
# Transmogrification core methods
|
||||
|
||||
def visit_module(self, path: str) -> None:
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue