From 809452caab7b1b0050af7dfa9f04bfa12bdb2c75 Mon Sep 17 00:00:00 2001 From: Jinzhe Zeng Date: Sat, 9 Jul 2022 19:17:13 -0400 Subject: [PATCH] refactor sphinx plugin (#14) * refactor sphinx plugin Change the way to generate documentation with fewer codes. This does not have any changes in the output. Also, add more sub_items/sub_variants displayed in the dargs documentation, for test purpose. * remove the debug line * `items` is not required any more --- dargs/sphinx.py | 53 +++++++++++++++---------------------------------- 1 file changed, 16 insertions(+), 37 deletions(-) diff --git a/dargs/sphinx.py b/dargs/sphinx.py index 6baab54..1a4a42a 100644 --- a/dargs/sphinx.py +++ b/dargs/sphinx.py @@ -21,35 +21,11 @@ """ import sys -from docutils import nodes -from docutils.parsers.rst import Directive, Parser +from docutils.parsers.rst import Directive from docutils.parsers.rst.directives import unchanged -from docutils.statemachine import ViewList -from docutils.frontend import OptionParser -from docutils.utils import new_document from .dargs import Argument, Variant -def parse_rst(text: str) -> nodes.document: - """Parse rst texts to nodes. - - Parameters - ---------- - text : str - raw rst texts - - Returns - ------- - nodes.document - nodes - """ - parser = Parser() - components = (Parser,) - settings = OptionParser(components=components).get_default_values() - document = new_document('', settings=settings) - parser.parse(text, document) - return document - class DargsDirective(Directive): """dargs directive""" @@ -80,21 +56,12 @@ def run(self): if not isinstance(arguments, (list, tuple)): arguments = [arguments] - items = [] for argument in arguments: if not isinstance(argument, (Argument, Variant)): raise RuntimeError("The function doesn't return Argument") rst = argument.gen_doc(make_anchor=True, make_link=True) - node = parse_rst(rst) - self.state.document.nameids.update(node.nameids) - self.state.document.ids.update(node.ids) - self.state.document.refnames.update(node.refnames) - self.state.document.substitution_defs.update(node.substitution_defs) - self.state.document.substitution_names.update(node.substitution_names) - self.state.document.nametypes.update(node.nametypes) - self.state.document.indirect_targets.extend(node.indirect_targets) - items.extend(node) - return items + self.state_machine.insert_input(rst.split("\n"), "%s:%s" %(module_name, attr_name)) + return [] def setup(app): @@ -105,4 +72,16 @@ def setup(app): def _test_argument() -> Argument: """This internal function is used to generate docs of dargs.""" - return Argument(name="test", dtype=str, doc="This argument is only used to test.") + doc_test = "This argument/variant is only used to test." + return Argument(name="test", dtype=str, doc=doc_test, + sub_fields=[ + Argument("test_argument", dtype=str, doc=doc_test, default="test"), + ], + sub_variants=[ + Variant("test_variant", doc=doc_test, + choices=[ + Argument("test_variant_argument", dtype=str, doc=doc_test), + ], + ), + ], + )