annotate 0.6.1/modules/cat/fastq/main.nf @ 11:749faef1caa9

"planemo upload"
author kkonganti
date Tue, 05 Sep 2023 11:51:40 -0400
parents
children
rev   line source
kkonganti@11 1 process CAT_FASTQ {
kkonganti@11 2 tag "$meta.id"
kkonganti@11 3 label 'process_micro'
kkonganti@11 4
kkonganti@11 5 conda (params.enable_conda ? "conda-forge::sed=4.7 conda-forge::gzip" : null)
kkonganti@11 6 container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ?
kkonganti@11 7 'https://containers.biocontainers.pro/s3/SingImgsRepo/biocontainers/v1.2.0_cv1/biocontainers_v1.2.0_cv1.img' :
kkonganti@11 8 'biocontainers/biocontainers:v1.2.0_cv1' }"
kkonganti@11 9
kkonganti@11 10 input:
kkonganti@11 11 tuple val(meta), path(reads, stageAs: "input*/*")
kkonganti@11 12
kkonganti@11 13 output:
kkonganti@11 14 tuple val(meta), path("*.merged.fastq.gz"), emit: catted_reads
kkonganti@11 15 path "versions.yml" , emit: versions
kkonganti@11 16
kkonganti@11 17 when:
kkonganti@11 18 task.ext.when == null || task.ext.when
kkonganti@11 19
kkonganti@11 20 script:
kkonganti@11 21 def args = task.ext.args ?: ''
kkonganti@11 22 def prefix = task.ext.prefix ?: "${meta.id}"
kkonganti@11 23 def readList = reads.collect{ it.toString() }
kkonganti@11 24 def is_in_gz = readList[0].endsWith('.gz')
kkonganti@11 25 def gz_or_ungz = (is_in_gz ? '' : ' | gzip')
kkonganti@11 26 def pigz_or_ungz = (is_in_gz ? '' : " | pigz -p ${task.cpus}")
kkonganti@11 27 if (meta.single_end) {
kkonganti@11 28 if (readList.size > 1) {
kkonganti@11 29 """
kkonganti@11 30 zcmd="gzip"
kkonganti@11 31 zver=""
kkonganti@11 32
kkonganti@11 33 if type pigz > /dev/null 2>&1; then
kkonganti@11 34 cat ${readList.join(' ')} ${pigz_or_ungz} > ${prefix}.merged.fastq.gz
kkonganti@11 35 zcmd="pigz"
kkonganti@11 36 zver=\$( echo \$( \$zcmd --version 2>&1 ) | sed -e '1!d' | sed "s/\$zcmd //" )
kkonganti@11 37 else
kkonganti@11 38 cat ${readList.join(' ')} ${gz_or_ungz} > ${prefix}.merged.fastq.gz
kkonganti@11 39 zcmd="gzip"
kkonganti@11 40
kkonganti@11 41 if [ "${workflow.containerEngine}" != "null" ]; then
kkonganti@11 42 zver=\$( echo \$( \$zcmd --help 2>&1 ) | sed -e '1!d; s/ (.*\$//' )
kkonganti@11 43 else
kkonganti@11 44 zver=\$( echo \$( \$zcmd --version 2>&1 ) | sed "s/^.*(\$zcmd) //; s/\$zcmd //; s/ Copyright.*\$//" )
kkonganti@11 45 fi
kkonganti@11 46 fi
kkonganti@11 47
kkonganti@11 48 cat <<-END_VERSIONS > versions.yml
kkonganti@11 49 "${task.process}":
kkonganti@11 50 cat: \$( echo \$(cat --version 2>&1) | sed 's/^.*coreutils) //; s/ .*\$//' )
kkonganti@11 51 \$zcmd: \$zver
kkonganti@11 52 END_VERSIONS
kkonganti@11 53 """
kkonganti@11 54 }
kkonganti@11 55 } else {
kkonganti@11 56 if (readList.size > 2) {
kkonganti@11 57 def read1 = []
kkonganti@11 58 def read2 = []
kkonganti@11 59 readList.eachWithIndex{ v, ix -> ( ix & 1 ? read2 : read1 ) << v }
kkonganti@11 60 """
kkonganti@11 61 zcmd="gzip"
kkonganti@11 62 zver=""
kkonganti@11 63
kkonganti@11 64 if type pigz > /dev/null 2>&1; then
kkonganti@11 65 cat ${read1.join(' ')} ${pigz_or_ungz} > ${prefix}_1.merged.fastq.gz
kkonganti@11 66 cat ${read2.join(' ')} ${pigz_or_ungz} > ${prefix}_2.merged.fastq.gz
kkonganti@11 67 zcmd="pigz"
kkonganti@11 68 zver=\$( echo \$( \$zcmd --version 2>&1 ) | sed -e '1!d' | sed "s/\$zcmd //" )
kkonganti@11 69 else
kkonganti@11 70 cat ${read1.join(' ')} ${gz_or_ungz} > ${prefix}_1.merged.fastq.gz
kkonganti@11 71 cat ${read2.join(' ')} ${gz_or_ungz} > ${prefix}_2.merged.fastq.gz
kkonganti@11 72 zcmd="gzip"
kkonganti@11 73
kkonganti@11 74 if [ "${workflow.containerEngine}" != "null" ]; then
kkonganti@11 75 zver=\$( echo \$( \$zcmd --help 2>&1 ) | sed -e '1!d; s/ (.*\$//' )
kkonganti@11 76 else
kkonganti@11 77 zver=\$( echo \$( \$zcmd --version 2>&1 ) | sed "s/^.*(\$zcmd) //; s/\$zcmd //; s/ Copyright.*\$//" )
kkonganti@11 78 fi
kkonganti@11 79 fi
kkonganti@11 80
kkonganti@11 81 cat <<-END_VERSIONS > versions.yml
kkonganti@11 82 "${task.process}":
kkonganti@11 83 cat: \$( echo \$(cat --version 2>&1) | sed 's/^.*coreutils) //; s/ .*\$//' )
kkonganti@11 84 \$zcmd: \$zver
kkonganti@11 85 END_VERSIONS
kkonganti@11 86 """
kkonganti@11 87 }
kkonganti@11 88 }
kkonganti@11 89 }