diff options
-rw-r--r-- | Makefile | 4 | ||||
-rwxr-xr-x | scripts/build-command-templates | 31 |
2 files changed, 16 insertions, 19 deletions
@@ -6,7 +6,7 @@ OP_TMPL_DIR := templates-op interface_definitions: mkdir -p $(TMPL_DIR) - find $(CURDIR)/interface-definitions/ -type f | xargs -I {} $(CURDIR)/scripts/build-command-templates {} $(CURDIR)/schema/interface_definition.rng $(TMPL_DIR) + find $(CURDIR)/interface-definitions/ -type f | xargs -I {} $(CURDIR)/scripts/build-command-templates {} $(CURDIR)/schema/interface_definition.rng $(TMPL_DIR) || exit 1 # XXX: delete top level node.def's that now live in other packages rm -f $(TMPL_DIR)/system/node.def @@ -19,7 +19,7 @@ interface_definitions: op_mode_definitions: mkdir -p $(OP_TMPL_DIR) - find $(CURDIR)/op-mode-definitions/ -type f | xargs -I {} $(CURDIR)/scripts/build-command-op-templates {} $(CURDIR)/schema/op-mode-definition.rng $(OP_TMPL_DIR) + find $(CURDIR)/op-mode-definitions/ -type f | xargs -I {} $(CURDIR)/scripts/build-command-op-templates {} $(CURDIR)/schema/op-mode-definition.rng $(OP_TMPL_DIR) || exit 1 # XXX: delete top level op mode node.def's that now live in other packages rm -f $(OP_TMPL_DIR)/show/node.def diff --git a/scripts/build-command-templates b/scripts/build-command-templates index 88223ea80..07e7d522a 100755 --- a/scripts/build-command-templates +++ b/scripts/build-command-templates @@ -50,7 +50,7 @@ schema_file = args.SCHEMA_FILE output_dir = args.OUTPUT_DIR debug = args.debug -debug = True +#debug = True ## Load and validate the inputs @@ -109,24 +109,25 @@ def get_properties(p): props["val_help"] = [] # Get the constraint statements + error_msg = default_constraint_err_msg + # Get the error message if it's there try: - error_msg = default_constraint_err_msg - # Get the error message if it's there - try: - error_msg = p.find("constraintErrorMessage").text - except: - pass - - vce = p.find("constraint") - vc = [] + error_msg = p.find("constraintErrorMessage").text + except: + pass + vce = p.find("constraint") + vc = [] + if vce is not None: # The old backend doesn't support multiple validators in OR mode # so we emulate it - regex_elements = vce.findall("regex") regexes = [] + regex_elements = vce.findall("regex") if regex_elements is not None: - regexes = list(map(lambda e: e.text, regex_elements)) + regexes = list(map(lambda e: e.text.strip(), regex_elements)) + if "" in regexes: + print("Warning: empty regex, node will be accepting any value") validator_elements = vce.findall("validator") validators = [] @@ -152,9 +153,6 @@ def get_properties(p): validator_string = "exec \"{0} {1} {2} --value \\\'$VAR(@)\\\'\"; \"{3}\"".format(validator_script, regex_args, validator_args, error_msg) props["constraint"] = validator_string - except Exception as exn: - print(exn) - pass # Get the completion help strings try: @@ -248,8 +246,7 @@ def process_node(n, tmpl_dir): my_tmpl_dir.append(name) - if debug: - print("Name of the node: {};\n Created directory: ".format(name), end="") + print("Name of the node: {0}. Created directory: {1}\n".format(name, "/".join(my_tmpl_dir)), end="") os.makedirs(make_path(my_tmpl_dir), exist_ok=True) props = get_properties(props_elem) |