diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 16:29:01 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 16:29:01 +0000 |
commit | 35a96bde514a8897f6f0fcc41c5833bf63df2e2a (patch) | |
tree | 657d15a03cc46bd099fc2c6546a7a4ad43815d9f /share/extensions/tools | |
parent | Initial commit. (diff) | |
download | inkscape-35a96bde514a8897f6f0fcc41c5833bf63df2e2a.tar.xz inkscape-35a96bde514a8897f6f0fcc41c5833bf63df2e2a.zip |
Adding upstream version 1.0.2.upstream/1.0.2upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r-- | share/extensions/tools/generate_argparse_conf.py | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/share/extensions/tools/generate_argparse_conf.py b/share/extensions/tools/generate_argparse_conf.py new file mode 100644 index 0000000..fda9145 --- /dev/null +++ b/share/extensions/tools/generate_argparse_conf.py @@ -0,0 +1,60 @@ +# coding=utf-8 +import os +from string import Template +import xml.etree.ElementTree as ET +import argparse + +parser = argparse.ArgumentParser(description='Reads an *.inx file and generates initialization code for argparse') +parser.add_argument('input') +args = parser.parse_args() + +if os.path.isabs(args.input): + inpath = args.input +else: + folder = os.path.dirname(os.path.realpath(__file__)) + inpath = os.path.normpath(os.path.join(folder, args.input)) + +templateWithType = Template('self.arg_parser.add_argument("--$param", type=$type, dest="$param", default=$default)') +templateWithoutType = Template('self.arg_parser.add_argument("--$param", dest="$param", default=$default)') +def handle_param_node(node): + if node.attrib["type"] == 'float': + cmd = templateWithType.substitute( + param=node.attrib["name"], + type='float', + default=node.text) + print(cmd) + elif node.attrib["type"] == 'int': + cmd = templateWithType.substitute( + param=node.attrib["name"], + type='int', + default=node.text) + print(cmd) + elif node.attrib["type"] == 'boolean': + cmd = templateWithType.substitute( + param=node.attrib["name"], + type='inkex.inkbool', + default='"' + node.text + '"') + print(cmd) + elif node.attrib["type"] == 'enum': + cmd = templateWithoutType.substitute( + param=node.attrib["name"], + default='"' + node[0].text + '"') + print(cmd) + elif node.attrib["type"] == 'notebook': + cmd = templateWithoutType.substitute( + param=node.attrib["name"], + default='"' + node[0].attrib["name"] + '"') + print(cmd) + else: + # TODO: Implement other types of args + raise NotImplementedError + +def process_node(node): + for child in node: + if child.tag.endswith('param'): + handle_param_node(child) + process_node(child) + +tree = ET.parse(inpath) +root = tree.getroot() +process_node(root)
\ No newline at end of file |