annotate 0.1.0/modules/quast/main.nf @ 0:c8597e9e1a97

"planemo upload"
author kkonganti
date Mon, 27 Nov 2023 12:37:44 -0500
parents
children
rev   line source
kkonganti@0 1 process QUAST {
kkonganti@0 2 tag "$meta.id"
kkonganti@0 3 label "process_micro"
kkonganti@0 4
kkonganti@0 5 module (params.enable_module ? "${params.swmodulepath}${params.fs}quast${params.fs}5.2.0" : null)
kkonganti@0 6 conda (params.enable_conda ? "bioconda::quast=5.2.0 conda-forge::libgcc-ng" : null)
kkonganti@0 7 container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ?
kkonganti@0 8 'https://depot.galaxyproject.org/singularity/quast:5.2.0--py39pl5321h2add14b_1' :
kkonganti@0 9 'biocontainers/quast:5.2.0--py39pl5321h2add14b_1' }"
kkonganti@0 10
kkonganti@0 11 input:
kkonganti@0 12 tuple val(meta) , path(consensus)
kkonganti@0 13 tuple val(meta2), path(fasta)
kkonganti@0 14 tuple val(meta3), path(gff)
kkonganti@0 15
kkonganti@0 16 output:
kkonganti@0 17 tuple val(meta), path("${prefix}") , emit: results
kkonganti@0 18 tuple val(meta), path("${prefix}.quastreport.tsv") , emit: tsv
kkonganti@0 19 tuple val(meta), path("${prefix}_transcriptome.tsv"), emit: transcriptome, optional: true
kkonganti@0 20 tuple val(meta), path("${prefix}_misassemblies.tsv"), emit: misassemblies, optional: true
kkonganti@0 21 tuple val(meta), path("${prefix}_unaligned.tsv") , emit: unaligned , optional: true
kkonganti@0 22 path "versions.yml" , emit: versions
kkonganti@0 23
kkonganti@0 24 when:
kkonganti@0 25 task.ext.when == null || task.ext.when
kkonganti@0 26
kkonganti@0 27 script:
kkonganti@0 28 def args = task.ext.args ?: ''
kkonganti@0 29 prefix = task.ext.prefix ?: "${meta.id}"
kkonganti@0 30 def reference = fasta ? "-r $fasta" : ''
kkonganti@0 31 def features = gff ? "--features $gff" : ''
kkonganti@0 32 """
kkonganti@0 33 quast.py \\
kkonganti@0 34 -l $prefix \\
kkonganti@0 35 --output-dir $prefix \\
kkonganti@0 36 $reference \\
kkonganti@0 37 $features \\
kkonganti@0 38 --threads $task.cpus \\
kkonganti@0 39 $args \\
kkonganti@0 40 ${consensus.join(' ')}
kkonganti@0 41
kkonganti@0 42 ln -s ${prefix}/report.tsv ${prefix}.quastreport.tsv
kkonganti@0 43 [ -f ${prefix}/contigs_reports/all_alignments_transcriptome.tsv ] && ln -s ${prefix}/contigs_reports/all_alignments_transcriptome.tsv ${prefix}_transcriptome.tsv
kkonganti@0 44 [ -f ${prefix}/contigs_reports/misassemblies_report.tsv ] && ln -s ${prefix}/contigs_reports/misassemblies_report.tsv ${prefix}_misassemblies.tsv
kkonganti@0 45 [ -f ${prefix}/contigs_reports/unaligned_report.tsv ] && ln -s ${prefix}/contigs_reports/unaligned_report.tsv ${prefix}_unaligned.tsv
kkonganti@0 46
kkonganti@0 47 cat <<-END_VERSIONS > versions.yml
kkonganti@0 48 "${task.process}":
kkonganti@0 49 quast: \$(quast.py --version 2>&1 | sed 's/^.*QUAST v//; s/ .*\$//')
kkonganti@0 50 bash: \$( bash --version 2>&1 | sed '1!d; s/^.*version //; s/ (.*\$//' )
kkonganti@0 51 END_VERSIONS
kkonganti@0 52
kkonganti@0 53 zcmd=""
kkonganti@0 54 zver=""
kkonganti@0 55
kkonganti@0 56 if type pigz > /dev/null 2>&1; then
kkonganti@0 57 zcmd="pigz"
kkonganti@0 58 zver=\$( echo \$( \$zcmd --version 2>&1 ) | sed -e '1!d' | sed "s/\$zcmd //" )
kkonganti@0 59 elif type gzip > /dev/null 2>&1; then
kkonganti@0 60 zcmd="gzip"
kkonganti@0 61
kkonganti@0 62 if [ "${workflow.containerEngine}" != "null" ]; then
kkonganti@0 63 zver=\$( echo \$( \$zcmd --help 2>&1 ) | sed -e '1!d; s/ (.*\$//' )
kkonganti@0 64 else
kkonganti@0 65 zver=\$( echo \$( \$zcmd --version 2>&1 ) | sed "s/^.*(\$zcmd) //; s/\$zcmd //; s/ Copyright.*\$//" )
kkonganti@0 66 fi
kkonganti@0 67 fi
kkonganti@0 68
kkonganti@0 69 cat <<-END_VERSIONS >> versions.yml
kkonganti@0 70 \$zcmd: \$zver
kkonganti@0 71 END_VERSIONS
kkonganti@0 72 """
kkonganti@0 73 }