|
1 | 1 | process BLAST_MAKEBLASTDB {
|
2 |
| - tag "$fasta" |
| 2 | + tag "$meta.id" |
3 | 3 | label 'process_medium'
|
4 | 4 |
|
5 |
| - conda "bioconda::blast=2.13.0" |
| 5 | + conda "${moduleDir}/environment.yml" |
6 | 6 | container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ?
|
7 |
| - 'https://depot.galaxyproject.org/singularity/blast:2.13.0--hf3cf87c_0' : |
8 |
| - 'biocontainers/blast:2.13.0--hf3cf87c_0' }" |
| 7 | + 'https://depot.galaxyproject.org/singularity/blast:2.15.0--pl5321h6f7f691_1': |
| 8 | + 'biocontainers/blast:2.15.0--pl5321h6f7f691_1' }" |
9 | 9 |
|
10 | 10 | input:
|
11 |
| - path fasta |
| 11 | + tuple val(meta), path(fasta) |
12 | 12 |
|
13 | 13 | output:
|
14 |
| - path 'blast_db' , emit: db |
15 |
| - path "versions.yml" , emit: versions |
| 14 | + tuple val(meta), path("${meta.id}"), emit: db |
| 15 | + path "versions.yml" , emit: versions |
16 | 16 |
|
17 | 17 | when:
|
18 | 18 | task.ext.when == null || task.ext.when
|
19 | 19 |
|
20 | 20 | script:
|
21 | 21 | def args = task.ext.args ?: ''
|
| 22 | + def prefix = task.ext.prefix ?: "${meta.id}" |
| 23 | + def is_compressed = fasta.getExtension() == "gz" ? true : false |
| 24 | + def fasta_name = is_compressed ? fasta.getBaseName() : fasta |
22 | 25 | """
|
| 26 | + if [ "${is_compressed}" == "true" ]; then |
| 27 | + gzip -c -d ${fasta} > ${fasta_name} |
| 28 | + fi |
| 29 | +
|
23 | 30 | makeblastdb \\
|
24 |
| - -in $fasta \\ |
25 |
| - $args |
26 |
| - mkdir blast_db |
27 |
| - mv ${fasta}* blast_db |
| 31 | + -in ${fasta_name} \\ |
| 32 | + ${args} |
| 33 | + mkdir ${prefix} |
| 34 | + mv ${fasta_name}* ${prefix} |
| 35 | +
|
| 36 | + cat <<-END_VERSIONS > versions.yml |
| 37 | + "${task.process}": |
| 38 | + blast: \$(blastn -version 2>&1 | sed 's/^.*blastn: //; s/ .*\$//') |
| 39 | + END_VERSIONS |
| 40 | + """ |
| 41 | + |
| 42 | + stub: |
| 43 | + def args = task.ext.args ?: '' |
| 44 | + def prefix = task.ext.prefix ?: "${meta.id}" |
| 45 | + def is_compressed = fasta.getExtension() == "gz" ? true : false |
| 46 | + def fasta_name = is_compressed ? fasta.getBaseName() : fasta |
| 47 | + """ |
| 48 | + touch ${fasta_name}.fasta |
| 49 | + touch ${fasta_name}.fasta.ndb |
| 50 | + touch ${fasta_name}.fasta.nhr |
| 51 | + touch ${fasta_name}.fasta.nin |
| 52 | + touch ${fasta_name}.fasta.njs |
| 53 | + touch ${fasta_name}.fasta.not |
| 54 | + touch ${fasta_name}.fasta.nsq |
| 55 | + touch ${fasta_name}.fasta.ntf |
| 56 | + touch ${fasta_name}.fasta.nto |
| 57 | + mkdir ${prefix} |
| 58 | + mv ${fasta_name}* ${prefix} |
| 59 | +
|
28 | 60 | cat <<-END_VERSIONS > versions.yml
|
29 | 61 | "${task.process}":
|
30 | 62 | blast: \$(blastn -version 2>&1 | sed 's/^.*blastn: //; s/ .*\$//')
|
|
0 commit comments