Mercurial > repos > peterjc > mira4_assembler
view tools/mira4_0/mira4_validator.py @ 38:cee8f9005e43 draft
planemo upload for repository https://github.com/peterjc/galaxy_mira/tree/master/tools/mira4_0 commit 206259620376b322fc8ed99a6efdd3712f38764b
author | peterjc |
---|---|
date | Wed, 11 Jul 2018 12:35:35 -0400 |
parents | 56b421d59805 |
children | bbf14bb9607b |
line wrap: on
line source
"""Python code to validate parameters in the Galaxy XML definition.""" # Called from the Galaxy Tool XML file # import sys def validate_input(trans, error_map, param_values, page_param_map): """Validate the min_size/max_size user input, before execution.""" err_list = [] for read_group in param_values["read_group"]: err = dict() segments = read_group["segments"] if str(segments["type"]) != "paired": err_list.append(dict()) continue min_size = str(segments["min_size"]).strip() max_size = str(segments["max_size"]).strip() # sys.stderr.write("DEBUG min_size=%r, max_size=%r\n" % (min_size, max_size)) # Somehow Galaxy seems to turn an empty field into string "None"... if min_size == "None": min_size = "" if max_size == "None": max_size = "" if min_size == "" and max_size == "": # Both missing is good pass elif min_size == "": err["min_size"] = "Minimum size required if maximum size given" elif max_size == "": err["max_size"] = "Maximum size required if minimum size given" if min_size: try: min_size_int = int(min_size) if min_size_int < 0: err["min_size"] = "Minumum size must not be negative (%i)" % min_size_int min_size = None # Avoid doing comparison below except ValueError: err["min_size"] = "Minimum size is not an integer (%s)" % min_size min_size = None # Avoid doing comparison below if max_size: try: max_size_int = int(max_size) if max_size_int < 0: err["max_size"] = "Maximum size must not be negative (%i)" % max_size_int max_size = None # Avoid doing comparison below except ValueError: err["max_size"] = "Maximum size is not an integer (%s)" % max_size max_size = None # Avoid doing comparison below if min_size and max_size and min_size_int > max_size_int: msg = "Minimum size must be less than maximum size (%i vs %i)" % (min_size_int, max_size_int) err["min_size"] = msg err["max_size"] = msg if err: err_list.append({"segments": err}) else: err_list.append(dict()) if any(err_list): # Return an error map only if any readgroup gave errors error_map["read_group"] = err_list