kkonganti@0: process CAT_FASTQ { kkonganti@0: tag "$meta.id" kkonganti@0: label 'process_micro' kkonganti@0: kkonganti@0: conda (params.enable_conda ? "conda-forge::sed=4.7 conda-forge::gzip" : null) kkonganti@0: container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ? kkonganti@0: 'https://containers.biocontainers.pro/s3/SingImgsRepo/biocontainers/v1.2.0_cv1/biocontainers_v1.2.0_cv1.img' : kkonganti@0: 'biocontainers/biocontainers:v1.2.0_cv1' }" kkonganti@0: kkonganti@0: input: kkonganti@0: tuple val(meta), path(reads, stageAs: "input*/*") kkonganti@0: kkonganti@0: output: kkonganti@0: tuple val(meta), path("*.merged.fastq.gz"), emit: catted_reads kkonganti@0: path "versions.yml" , emit: versions kkonganti@0: kkonganti@0: when: kkonganti@0: task.ext.when == null || task.ext.when kkonganti@0: kkonganti@0: script: kkonganti@0: def args = task.ext.args ?: '' kkonganti@0: def prefix = task.ext.prefix ?: "${meta.id}" kkonganti@0: def readList = reads.collect{ it.toString() } kkonganti@0: def is_in_gz = readList[0].endsWith('.gz') kkonganti@0: def gz_or_ungz = (is_in_gz ? '' : ' | gzip') kkonganti@0: def pigz_or_ungz = (is_in_gz ? '' : " | pigz -p ${task.cpus}") kkonganti@0: if (meta.single_end) { kkonganti@0: if (readList.size > 1) { kkonganti@0: """ kkonganti@0: zcmd="gzip" kkonganti@0: zver="" kkonganti@0: kkonganti@0: if type pigz > /dev/null 2>&1; then kkonganti@0: cat ${readList.join(' ')} ${pigz_or_ungz} > ${prefix}.merged.fastq.gz kkonganti@0: zcmd="pigz" kkonganti@0: zver=\$( echo \$( \$zcmd --version 2>&1 ) | sed -e '1!d' | sed "s/\$zcmd //" ) kkonganti@0: else kkonganti@0: cat ${readList.join(' ')} ${gz_or_ungz} > ${prefix}.merged.fastq.gz kkonganti@0: zcmd="gzip" kkonganti@0: kkonganti@0: if [ "${workflow.containerEngine}" != "null" ]; then kkonganti@0: zver=\$( echo \$( \$zcmd --help 2>&1 ) | sed -e '1!d; s/ (.*\$//' ) kkonganti@0: else kkonganti@0: zver=\$( echo \$( \$zcmd --version 2>&1 ) | sed "s/^.*(\$zcmd) //; s/\$zcmd //; s/ Copyright.*\$//" ) kkonganti@0: fi kkonganti@0: fi kkonganti@0: kkonganti@0: cat <<-END_VERSIONS > versions.yml kkonganti@0: "${task.process}": kkonganti@0: cat: \$( echo \$(cat --version 2>&1) | sed 's/^.*coreutils) //; s/ .*\$//' ) kkonganti@0: \$zcmd: \$zver kkonganti@0: END_VERSIONS kkonganti@0: """ kkonganti@0: } kkonganti@0: } else { kkonganti@0: if (readList.size > 2) { kkonganti@0: def read1 = [] kkonganti@0: def read2 = [] kkonganti@0: readList.eachWithIndex{ v, ix -> ( ix & 1 ? read2 : read1 ) << v } kkonganti@0: """ kkonganti@0: zcmd="gzip" kkonganti@0: zver="" kkonganti@0: kkonganti@0: if type pigz > /dev/null 2>&1; then kkonganti@0: cat ${read1.join(' ')} ${pigz_or_ungz} > ${prefix}_1.merged.fastq.gz kkonganti@0: cat ${read2.join(' ')} ${pigz_or_ungz} > ${prefix}_2.merged.fastq.gz kkonganti@0: zcmd="pigz" kkonganti@0: zver=\$( echo \$( \$zcmd --version 2>&1 ) | sed -e '1!d' | sed "s/\$zcmd //" ) kkonganti@0: else kkonganti@0: cat ${read1.join(' ')} ${gz_or_ungz} > ${prefix}_1.merged.fastq.gz kkonganti@0: cat ${read2.join(' ')} ${gz_or_ungz} > ${prefix}_2.merged.fastq.gz kkonganti@0: zcmd="gzip" kkonganti@0: kkonganti@0: if [ "${workflow.containerEngine}" != "null" ]; then kkonganti@0: zver=\$( echo \$( \$zcmd --help 2>&1 ) | sed -e '1!d; s/ (.*\$//' ) kkonganti@0: else kkonganti@0: zver=\$( echo \$( \$zcmd --version 2>&1 ) | sed "s/^.*(\$zcmd) //; s/\$zcmd //; s/ Copyright.*\$//" ) kkonganti@0: fi kkonganti@0: fi kkonganti@0: kkonganti@0: cat <<-END_VERSIONS > versions.yml kkonganti@0: "${task.process}": kkonganti@0: cat: \$( echo \$(cat --version 2>&1) | sed 's/^.*coreutils) //; s/ .*\$//' ) kkonganti@0: \$zcmd: \$zver kkonganti@0: END_VERSIONS kkonganti@0: """ kkonganti@0: } kkonganti@0: } kkonganti@0: }