annotate 0.6.1/modules/kma/align/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 KMA_ALIGN {
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}kma${params.fs}1.4.4" : null)
kkonganti@11 6 conda (params.enable_conda ? "conda-forge::libgcc-ng bioconda::kma=1.4.3" : null)
kkonganti@11 7 container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ?
kkonganti@11 8 'https://depot.galaxyproject.org/singularity/kma:1.4.3--h7132678_1':
kkonganti@11 9 'quay.io/biocontainers/kma:1.4.3--h7132678_1' }"
kkonganti@11 10
kkonganti@11 11 input:
kkonganti@11 12 tuple val(meta), path(reads), path(index)
kkonganti@11 13
kkonganti@11 14 output:
kkonganti@11 15 path "${meta.id}_kma_res"
kkonganti@11 16 tuple val(meta), path("${meta.id}_kma_res${params.fs}*.res") , emit: res
kkonganti@11 17 tuple val(meta), path("${meta.id}_kma_res${params.fs}*.mapstat") , emit: mapstat, optional: true
kkonganti@11 18 tuple val(meta), path("${meta.id}_kma_res${params.fs}*.frag.gz") , emit: frags, optional: true
kkonganti@11 19 tuple val(meta), path("${meta.id}_kma_res${params.fs}*_template_hits.txt"), emit: hits, optional: true
kkonganti@11 20 path "versions.yml" , emit: versions
kkonganti@11 21
kkonganti@11 22 when:
kkonganti@11 23 task.ext.when == null || task.ext.when
kkonganti@11 24
kkonganti@11 25 script:
kkonganti@11 26 def args = task.ext.args ?: ''
kkonganti@11 27 def prefix = task.ext.prefix ?: "${meta.id}"
kkonganti@11 28 def reads_in = (meta.single_end ? "-i $reads" : "-ipe ${reads[0]} ${reads[1]}")
kkonganti@11 29 def db = (meta.kma_t_db ?: "${index}")
kkonganti@11 30 def db_basename = (db ? "${index.baseName}" : '')
kkonganti@11 31 def get_hit_accs = (meta.get_kma_hit_accs ? 'true' : 'false')
kkonganti@11 32 def res_dir = prefix + '_kma_res'
kkonganti@11 33 reads_in = (params.kmaalign_int ? "-int $reads" : "-i $reads")
kkonganti@11 34 """
kkonganti@11 35 mkdir -p $res_dir || exit 1
kkonganti@11 36 kma \\
kkonganti@11 37 $args \\
kkonganti@11 38 -t_db $db${params.fs}$db_basename \\
kkonganti@11 39 -t $task.cpus \\
kkonganti@11 40 -o $res_dir${params.fs}$prefix \\
kkonganti@11 41 $reads_in
kkonganti@11 42
kkonganti@11 43 if [ "$get_hit_accs" == "true" ]; then
kkonganti@11 44 grep -v '^#' $res_dir${params.fs}${prefix}.res | \\
kkonganti@11 45 grep -E -o 'GC[AF]\\_[0-9]+\\.*[0-9]*' > $res_dir${params.fs}${prefix}_template_hits.txt
kkonganti@11 46 fi
kkonganti@11 47
kkonganti@11 48 cat <<-END_VERSIONS > versions.yml
kkonganti@11 49 "${task.process}":
kkonganti@11 50 kma: \$( kma -v | sed -e 's%KMA-%%' )
kkonganti@11 51 END_VERSIONS
kkonganti@11 52
kkonganti@11 53 mkdirver=""
kkonganti@11 54 cutver=""
kkonganti@11 55 grepver=""
kkonganti@11 56
kkonganti@11 57 if [ "${workflow.containerEngine}" != "null" ]; then
kkonganti@11 58 mkdirver=\$( mkdir --help 2>&1 | sed -e '1!d; s/ (.*\$//' | cut -f1-2 -d' ' )
kkonganti@11 59 cutver="\$mkdirver"
kkonganti@11 60 grepver="\$mkdirver"
kkonganti@11 61 else
kkonganti@11 62 mkdirver=\$( mkdir --version 2>&1 | sed '1!d; s/^.*(GNU coreutils//; s/) //;' )
kkonganti@11 63 cutver=\$( cut --version 2>&1 | sed '1!d; s/^.*(GNU coreutils//; s/) //;' )
kkonganti@11 64 grepver=\$( echo \$(grep --version 2>&1) | sed 's/^.*(GNU grep) //; s/ Copyright.*\$//' )
kkonganti@11 65 fi
kkonganti@11 66
kkonganti@11 67 cat <<-END_VERSIONS >> versions.yml
kkonganti@11 68 mkdir: \$mkdirver
kkonganti@11 69 cut: \$cutver
kkonganti@11 70 grep: \$grepver
kkonganti@11 71 END_VERSIONS
kkonganti@11 72 """
kkonganti@11 73 }