Mercurial > repos > galaxyp > openms_openswathdiaprescoring
annotate fill_ctd.py @ 14:a537d6b0141e draft default tip
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 2adf8edc3de4e1cd3b299b26abb14544d17d0636"
| author | galaxyp | 
|---|---|
| date | Fri, 06 Nov 2020 18:58:14 +0000 | 
| parents | 2ba1981c5a24 | 
| children | 
| rev | line source | 
|---|---|
| 13 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 1 import collections | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 2 import json | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 3 import operator | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 4 import os | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 5 import re | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 6 import subprocess | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 7 import sys | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 8 from functools import reduce # forward compatibility for Python 3 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 9 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 10 from CTDopts.CTDopts import ( | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 11 _Choices, | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 12 _InFile, | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 13 _Null, | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 14 _NumericRange, | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 15 CTDModel | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 16 ) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 17 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 18 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 19 def getFromDict(dataDict, mapList): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 20 return reduce(operator.getitem, mapList, dataDict) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 21 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 22 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 23 def setInDict(dataDict, mapList, value): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 24 getFromDict(dataDict, mapList[:-1])[mapList[-1]] = value | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 25 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 26 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 27 def mergeDicts(d, e): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 28 """ | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 29 insert values from the dict e into dict d | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 30 no values of d are overwritten | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 31 """ | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 32 for k, v in e.items(): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 33 if (k in d and isinstance(d[k], dict) and isinstance(e[k], collections.abc.Mapping)): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 34 mergeDicts(d[k], e[k]) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 35 elif k not in d and not isinstance(e[k], collections.abc.Mapping): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 36 d[k] = e[k] | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 37 else: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 38 sys.stderr.write("fill_ctd.py: could not merge key %s for %s in %s" % (k, d, e)) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 39 sys.exit(1) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 40 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 41 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 42 def _json_object_hook_noenvlookup(d): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 43 return _json_object_hook(d, envlookup=False) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 44 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 45 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 46 def _json_object_hook(d, envlookup=True): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 47 """ | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 48 wee helper to transform the json written by galaxy | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 49 while loading | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 50 - True/False (bool objects) -> "true"/"false" (lowercase string) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 51 - data inputs with multiple and optional true give [None] if no file is given -> [] | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 52 - None -> "" (empty string) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 53 - replace bash expressions (if envlookup is True): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 54 - environment variables (need to consist capital letters and _) by their value | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 55 - expressions | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 56 """ | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 57 for k in d.keys(): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 58 # if type(d[k]) is bool: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 59 # d[k] = str(d[k]).lower() | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 60 # else | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 61 if type(d[k]) is list and len(d[k]) == 1 and d[k][0] is None: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 62 d[k] = [] | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 63 elif d[k] is None: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 64 d[k] = "" | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 65 elif envlookup and type(d[k]) is str and d[k].startswith("$"): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 66 m = re.fullmatch(r"\$([A-Z_]+)", d[k]) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 67 if m: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 68 d[k] = os.environ.get(m.group(1), "") | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 69 continue | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 70 m = re.fullmatch(r"\$(\{[A-Z_]+):-(.*)\}", d[k]) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 71 if m: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 72 d[k] = os.environ.get(m.group(1), m.group(2)) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 73 continue | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 74 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 75 try: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 76 p = subprocess.run("echo %s" % d[k], shell=True, check=True, stdout=subprocess.PIPE, encoding="utf8") | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 77 d[k] = p.stdout.strip() | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 78 except subprocess.CalledProcessError: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 79 sys.stderr.write("fill_ctd error: Could not evaluate %s" % d[k]) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 80 continue | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 81 return d | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 82 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 83 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 84 def qstring2list(qs): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 85 """ | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 86 transform a space separated string that is quoted by " into a list | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 87 """ | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 88 lst = list() | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 89 qs = qs.split(" ") | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 90 quoted = False | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 91 for p in qs: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 92 if p == "": | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 93 continue | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 94 if p.startswith('"') and p.endswith('"'): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 95 lst.append(p[1:-1]) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 96 elif p.startswith('"'): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 97 quoted = True | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 98 lst.append(p[1:] + " ") | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 99 elif p.endswith('"'): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 100 quoted = False | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 101 lst[-1] += p[:-1] | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 102 else: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 103 if quoted: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 104 lst[-1] += p + " " | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 105 else: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 106 lst.append(p) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 107 return lst | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 108 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 109 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 110 def fix_underscores(args): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 111 if type(args) is dict: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 112 for k in list(args.keys()): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 113 v = args[k] | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 114 if type(v) is dict: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 115 fix_underscores(args[k]) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 116 if k.startswith("_"): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 117 args[k[1:]] = v | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 118 del args[k] | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 119 elif type(args) is list: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 120 for i, v in enumerate(args): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 121 if type(v) is dict: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 122 fix_underscores(args[i]) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 123 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 124 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 125 input_ctd = sys.argv[1] | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 126 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 127 # load user specified parameters from json | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 128 with open(sys.argv[2]) as fh: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 129 args = json.load(fh, object_hook=_json_object_hook_noenvlookup) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 130 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 131 # load hardcoded parameters from json | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 132 with open(sys.argv[3]) as fh: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 133 hc_args = json.load(fh, object_hook=_json_object_hook) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 134 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 135 # insert the hc_args into the args | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 136 mergeDicts(args, hc_args) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 137 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 138 if "adv_opts_cond" in args: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 139 args.update(args["adv_opts_cond"]) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 140 del args["adv_opts_cond"] | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 141 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 142 # IDMapper has in and spectra:in params, in is used in out as format_source", | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 143 # which does not work in Galaxy: https://github.com/galaxyproject/galaxy/pull/9493" | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 144 # therefore hardcoded params change the name of spectra:in to spectra:_in | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 145 # which is corrected here again | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 146 # TODO remove once PR is in and adapt profile accordingly | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 147 fix_underscores(args) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 148 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 149 model = CTDModel(from_file=input_ctd) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 150 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 151 # transform values from json that correspond to | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 152 # - old style booleans (string + restrictions) -> transformed to a str | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 153 # - new style booleans that get a string (happens for hidden parameters [-test]) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 154 # are transformed to a bool | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 155 # - unrestricted ITEMLIST which are represented as strings | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 156 # ("=quoted and space separated) in Galaxy -> transform to lists | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 157 # - optional data input parameters that have defaults and for which no | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 158 # value is given -> overwritte with the default | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 159 for p in model.get_parameters(): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 160 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 161 # check if the parameter is in the arguments from the galaxy tool | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 162 # (from the json file(s)), since advanced parameters are absent | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 163 # if the conditional is set to basic parameters | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 164 try: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 165 getFromDict(args, p.get_lineage(name_only=True)) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 166 except KeyError: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 167 # few tools use dashes in parameters which are automatically replaced | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 168 # by underscores by Galaxy. in these cases the dictionary needs to be | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 169 # updated (better: then dash and the underscore variant are in the dict) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 170 # TODO might be removed later https://github.com/OpenMS/OpenMS/pull/4529 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 171 try: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 172 lineage = [_.replace("-", "_") for _ in p.get_lineage(name_only=True)] | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 173 val = getFromDict(args, lineage) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 174 except KeyError: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 175 continue | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 176 else: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 177 setInDict(args, p.get_lineage(name_only=True), val) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 178 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 179 if p.type is str and type(p.restrictions) is _Choices and set(p.restrictions.choices) == set(["true", "false"]): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 180 v = getFromDict(args, p.get_lineage(name_only=True)) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 181 setInDict(args, p.get_lineage(name_only=True), str(v).lower()) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 182 elif p.type is bool: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 183 v = getFromDict(args, p.get_lineage(name_only=True)) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 184 if isinstance(v, str): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 185 v = (v.lower() == "true") | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 186 setInDict(args, p.get_lineage(name_only=True), v) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 187 elif p.is_list and (p.restrictions is None or type(p.restrictions) is _NumericRange): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 188 v = getFromDict(args, p.get_lineage(name_only=True)) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 189 if type(v) is str: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 190 setInDict(args, p.get_lineage(name_only=True), qstring2list(v)) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 191 elif p.type is _InFile and not (p.default is None or type(p.default) is _Null): | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 192 v = getFromDict(args, p.get_lineage(name_only=True)) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 193 if v in [[], ""]: | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 194 setInDict(args, p.get_lineage(name_only=True), p.default) | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 195 | 
| 
2ba1981c5a24
"planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 55a2aeba8bfd8a6910630721de9857dcdfe05d3c"
 galaxyp parents: diff
changeset | 196 model.write_ctd(input_ctd, arg_dict=args) | 
