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