-
Notifications
You must be signed in to change notification settings - Fork 125
/
Copy pathmirtrace.nf
51 lines (42 loc) · 1.5 KB
/
mirtrace.nf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
process MIRTRACE_RUN {
label 'process_medium'
conda 'bioconda::mirtrace=1.0.1'
container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ?
'https://depot.galaxyproject.org/singularity/mirtrace:1.0.1--hdfd78af_1' :
'biocontainers/mirtrace:1.0.1--hdfd78af_1' }"
input:
tuple val(adapter), val(ids), path(reads)
output:
path "mirtrace/*" , emit: mirtrace
path "versions.yml", emit: versions
when:
task.ext.when == null || task.ext.when
script:
// mirtrace protocol defaults to 'params.protocol' if not set
def primer = adapter ? "--adapter ${adapter}" : ""
def protocol = params.protocol == 'custom' ? '' : "--protocol $params.protocol"
def java_mem = ''
if(task.memory){
tmem = task.memory.toBytes()
java_mem = "-Xms${tmem} -Xmx${tmem}"
}
def config_lines = [ids,reads]
.transpose()
.collect({ id, path -> "echo '${path},${id}' >> mirtrace_config" })
"""
export mirtracejar=\$(dirname \$(which mirtrace))
${config_lines.join("\n ")}
java $java_mem -jar \$mirtracejar/mirtrace.jar --mirtrace-wrapper-name mirtrace qc \\
--species $params.mirtrace_species \\
$primer \\
$protocol \\
--config mirtrace_config \\
--write-fasta \\
--output-dir mirtrace \\
--force
cat <<-END_VERSIONS > versions.yml
"${task.process}":
mirtrace: \$(echo \$(mirtrace -v))
END_VERSIONS
"""
}