Source code for toil.options.wdl
from argparse import ArgumentParser
from configargparse import SUPPRESS
[docs]
def add_wdl_options(parser: ArgumentParser, suppress: bool = True) -> None:
"""
Add WDL options to a parser. This only adds nonpositional WDL arguments
:param parser: Parser to add options to
:param suppress: Suppress help output
:return: None
"""
suppress_help = SUPPRESS if suppress else None
# include arg names without a wdl specifier if suppress is False
# this is to avoid possible duplicate options in custom toil scripts, ex outputFile can be a common argument name
# TODO: Why do we even need them at all in other Toil scripts? Do we have to worry about dest= collisions?
# TODO: Can the better option name be first?
output_dialect_arguments = ["--wdlOutputDialect"] + (["--outputDialect"] if not suppress else [])
parser.add_argument(*output_dialect_arguments, dest="output_dialect", type=str, default='cromwell',
choices=['cromwell', 'miniwdl'],
help=suppress_help or ("JSON output format dialect. 'cromwell' just returns the workflow's "
"output values as JSON, while 'miniwdl' nests that under an 'outputs' "
"key, and includes a 'dir' key where files are written."))
output_directory_arguments = ["--wdlOutputDirectory"] + (["--outputDirectory", "-o"] if not suppress else [])
parser.add_argument(*output_directory_arguments, dest="output_directory", type=str, default=None,
help=suppress_help or (
"Directory or URI prefix to save output files at. By default a new directory is created "
"in the current directory."))
output_file_arguments = ["--wdlOutputFile"] + (["--outputFile", "-m"] if not suppress else [])
parser.add_argument(*output_file_arguments, dest="output_file", type=str, default=None,
help=suppress_help or "File or URI to save output JSON to.")
reference_inputs_arguments = ["--wdlReferenceInputs"] + (["--referenceInputs"] if not suppress else [])
parser.add_argument(*reference_inputs_arguments, dest="reference_inputs", type=bool, default=False,
help=suppress_help or "Pass input files by URL")
container_arguments = ["--wdlContainer"] + (["--container"] if not suppress else [])
parser.add_argument(*container_arguments, dest="container", type=str, choices=["singularity", "docker", "auto"], default="auto",
help=suppress_help or "Container engine to use to run WDL tasks")