Mercurial > repos > kkonganti > cfsan_centriflaken
diff 0.4.2/modules/kraken2/classify/main.nf @ 105:52045ea4679d
"planemo upload"
author | kkonganti |
---|---|
date | Thu, 27 Jun 2024 14:17:26 -0400 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/0.4.2/modules/kraken2/classify/main.nf Thu Jun 27 14:17:26 2024 -0400 @@ -0,0 +1,73 @@ +process KRAKEN2_CLASSIFY { + tag "$meta.id" + label 'process_low' + + module (params.enable_module ? "${params.swmodulepath}${params.fs}kraken2${params.fs}2.1.2" : null) + conda (params.enable_conda ? 'bioconda::kraken2=2.1.2 conda-forge::pigz=2.6' : null) + container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ? + 'https://depot.galaxyproject.org/singularity/mulled-v2-5799ab18b5fc681e75923b2450abaa969907ec98:87fc08d11968d081f3e8a37131c1f1f6715b6542-0' : + 'quay.io/biocontainers/mulled-v2-5799ab18b5fc681e75923b2450abaa969907ec98:87fc08d11968d081f3e8a37131c1f1f6715b6542-0' }" + + input: + tuple val(meta), path(reads) + + output: + tuple val(meta), path('*classified*') , emit: classified + tuple val(meta), path('*unclassified*'), emit: unclassified + tuple val(meta), path('*.report.txt') , emit: kraken_report + tuple val(meta), path('*.output.txt') , emit: kraken_output + path "versions.yml" , emit: versions + + when: + (task.ext.when == null || task.ext.when) && (meta.is_assembly ? reads.size() : 1) + + script: + def args = task.ext.args ?: '' + def db = meta.kraken2_db ?: '' + def prefix = task.ext.prefix ?: "${meta.id}" + def readList = reads.collect{ it.toString() } + def is_single_end = (meta.single_end || meta.is_assembly) ? true : false + def paired = is_single_end ? "" : "--paired" + def classified = is_single_end ? "--classified-out ${prefix}.classified.fastq" : "--classified-out ${prefix}.classified#.fastq" + def unclassified = is_single_end ? "--unclassified-out ${prefix}.unclassified.fastq" : "--unclassified-out ${prefix}.unclassified#.fastq" + args += (reads.getName().endsWith(".gz") ? ' --gzip-compressed ' : '') + """ + kraken2 \\ + --db $db \\ + --threads $task.cpus \\ + $unclassified \\ + $classified \\ + --report ${prefix}.kraken2.report.txt \\ + --output ${prefix}.kraken2.output.txt \\ + $paired \\ + $args \\ + $reads + + cat <<-END_VERSIONS > versions.yml + "${task.process}": + kraken2: \$(echo \$(kraken2 --version 2>&1) | sed 's/^.*Kraken version //; s/ .*\$//') + END_VERSIONS + + zcmd="" + zver="" + + if type pigz > /dev/null 2>&1; then + pigz -p $task.cpus *.fastq + zcmd="pigz" + zver=\$( echo \$( \$zcmd --version 2>&1 ) | sed -e '1!d' | sed "s/\$zcmd //" ) + elif type gzip > /dev/null 2>&1; then + gzip *.fastq + zcmd="gzip" + + if [ "${workflow.containerEngine}" != "null" ]; then + zver=\$( echo \$( \$zcmd --help 2>&1 ) | sed -e '1!d; s/ (.*\$//' ) + else + zver=\$( echo \$( \$zcmd --version 2>&1 ) | sed "s/^.*(\$zcmd) //; s/\$zcmd //; s/ Copyright.*\$//" ) + fi + fi + + cat <<-END_VERSIONS >> versions.yml + \$zcmd: \$zver + END_VERSIONS + """ +} \ No newline at end of file