annotate 0.7.0/modules/kma/align/main.nf @ 17:0e7a0053e4a6

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