From 765f4ceae8f45c44a76ecdfa951257a3059646ee Mon Sep 17 00:00:00 2001 From: Robrecht Cannoodt Date: Sun, 11 Feb 2024 21:49:10 +0100 Subject: [PATCH] refactor script --- src/star/star_align/script.py | 20 ++++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) diff --git a/src/star/star_align/script.py b/src/star/star_align/script.py index d3b073cf..e0f0fb0b 100644 --- a/src/star/star_align/script.py +++ b/src/star/star_align/script.py @@ -22,6 +22,7 @@ } ## VIASH END +################################################## # check and process SE / PE R1 input files fq1 = par["input"] input_str = ','.join(par["input"]) @@ -38,6 +39,8 @@ # store readFilesIn par["readFilesIn"] = input_str +################################################## + # determine readFilesCommand if fq1[0].endswith(".gz"): print(">> Input files are gzipped, setting readFilesCommand to zcat", flush=True) @@ -46,6 +49,7 @@ print(">> Input files are bzipped, setting readFilesCommand to bzcat", flush=True) par["readFilesCommand"] = "bzcat" +################################################## # store output paths expected_outputs = { "aligned_reads": ["Aligned.out.sam", "Aligned.out.bam"], @@ -60,17 +64,25 @@ for name in expected_outputs.keys(): par[name] = None +# TODO: Depending on the desired outputs, +# additional parameters might need to be set. + +################################################## +# process other args +par["runMode"] = "alignReads" + +if 'cpus' in meta and meta['cpus']: + par["runThreadN"] = meta["cpus"] + +################################################## +# run STAR and move output to final destination with tempfile.TemporaryDirectory(prefix="star-", dir=meta["temp_dir"], ignore_cleanup_errors=True) as temp_dir: print(">> Constructing command", flush=True) - par["runMode"] = "alignReads" par["outTmpDir"] = temp_dir + "/tempdir" par["outFileNamePrefix"] = temp_dir + "/out/" out_dir = Path(temp_dir) / "out" - if 'cpus' in meta and meta['cpus']: - par["runThreadN"] = meta["cpus"] - cmd_args = [ "STAR" ] for name, value in par.items(): if value is not None: