From b0cb07b39f46f175e786a2582963e1be4265acff Mon Sep 17 00:00:00 2001 From: Asher Glick Date: Sat, 3 Feb 2024 18:15:01 -0600 Subject: [PATCH 1/2] adding arguments to the generator command --- xml_converter/generators/main.py | 25 +++++++++++++++++++------ 1 file changed, 19 insertions(+), 6 deletions(-) diff --git a/xml_converter/generators/main.py b/xml_converter/generators/main.py index 271a45a9..468f7eaf 100644 --- a/xml_converter/generators/main.py +++ b/xml_converter/generators/main.py @@ -10,6 +10,8 @@ from protobuf_types import get_proto_field_type from util import capitalize, SchemaType, Document from generate_cpp import write_cpp_classes, write_attribute +import argparse +import sys XML_ATTRIBUTE_REGEX: Final[str] = "^[A-Za-z]+$" PROTO_FIELD_REGEX: Final[str] = "^[a-z_.]+$" @@ -364,6 +366,14 @@ def generate_auto_docs(self, metadata: Dict[str, SchemaType], content: Dict[str, # markdown files, and then creating the desired output files. ################################################################################ def main() -> None: + parser = argparse.ArgumentParser(description='Process some flags.') + parser.add_argument('--cpp-nodes', help='Generate the XML Node Classes.', action='store_true') + parser.add_argument('--cpp-attributes', help='Generate the XML Attribute functions.', action='store_true') + parser.add_argument('--documentation', help='Generate the HTML documentation.', action='store_true') + args = parser.parse_args() + + generate_all: bool = not args.cpp_nodes and not args.cpp_attributes and not args.documentation + generator = Generator() markdown_doc_directory = "../doc" @@ -372,14 +382,17 @@ def main() -> None: if os.path.isdir(full_markdown_doc_directory): generator.load_input_doc(full_markdown_doc_directory) - generator.delete_generated_docs("../web_docs") - generator.write_webdocs("../web_docs/") + if generate_all or args.documentation: + generator.delete_generated_docs("../web_docs") + generator.write_webdocs("../web_docs/") - written_classes = write_cpp_classes("../src/", generator.data) - generator.delete_generated_docs("../src/", skip=written_classes) + if generate_all or args.cpp_nodes: + written_classes = write_cpp_classes("../src/", generator.data) + generator.delete_generated_docs("../src/", skip=written_classes) - written_attributes = write_attribute("../src/attribute", generator.data) - generator.delete_generated_docs("../src/attribute", skip=written_attributes) + if generate_all or args.cpp_attributes: + written_attributes = write_attribute("../src/attribute", generator.data) + generator.delete_generated_docs("../src/attribute", skip=written_attributes) main() From 43d8f7d851cf61489402e353e1de7c6ca7ae1eb9 Mon Sep 17 00:00:00 2001 From: Asher Glick Date: Sat, 3 Feb 2024 18:17:55 -0600 Subject: [PATCH 2/2] removing sys import --- xml_converter/generators/main.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/xml_converter/generators/main.py b/xml_converter/generators/main.py index 468f7eaf..4e8464c3 100644 --- a/xml_converter/generators/main.py +++ b/xml_converter/generators/main.py @@ -11,7 +11,7 @@ from util import capitalize, SchemaType, Document from generate_cpp import write_cpp_classes, write_attribute import argparse -import sys + XML_ATTRIBUTE_REGEX: Final[str] = "^[A-Za-z]+$" PROTO_FIELD_REGEX: Final[str] = "^[a-z_.]+$"