annotate 1.0.0/modules/cat_cat/main.nf @ 0:801b85b03a17 draft default tip

planemo upload
author galaxytrakr
date Thu, 28 May 2026 20:31:42 +0000
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
1 process CAT_CAT {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
2 tag "$meta.id"
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
3 label 'process_micro'
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
4
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
5 module (params.enable_module ? "${params.swmodulepath}${params.fs}pigz${params.fs}2.7" : null)
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
6 conda (params.enable_conda ? "conda-forge::pigz=2.6" : null)
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
7 container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ?
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
8 'https://depot.galaxyproject.org/singularity/pigz:2.3.4' :
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
9 'quay.io/biocontainers/pigz:2.3.4' }"
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
10
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
11 input:
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
12 tuple val(meta), path(files_in)
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
13
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
14 output:
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
15 tuple val(meta), path("*${prefix}"), emit: concatenated_reads
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
16 path "versions.yml" , emit: versions
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
17
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
18 when:
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
19 task.ext.when == null || task.ext.when
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
20
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
21 script:
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
22 def args = task.ext.args ?: ''
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
23 def args2 = task.ext.args2 ?: ''
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
24 def file_list = files_in.collect { it.toString() }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
25
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
26 // | input | output | command1 | command2 |
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
27 // |-----------|------------|----------|----------|
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
28 // | gzipped | gzipped | cat | |
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
29 // | ungzipped | ungzipped | cat | |
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
30 // | gzipped | ungzipped | zcat | |
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
31 // | ungzipped | gzipped | cat | pigz |
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
32
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
33 // Use input file ending as default
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
34 prefix = task.ext.prefix ? "${meta.id}.${task.ext.prefix}" : "${meta.id}${file_list[0].substring(file_list[0].lastIndexOf('.'))}"
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
35 out_zip = prefix.endsWith('.gz')
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
36 in_zip = file_list[0].endsWith('.gz')
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
37 command1 = (in_zip && !out_zip) ? 'zcat' : 'cat'
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
38 command2 = (!in_zip && out_zip) ? "| pigz -c -p $task.cpus $args2" : ''
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
39 """
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
40 $command1 \\
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
41 $args \\
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
42 ${file_list.join(' ')} \\
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
43 $command2 \\
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
44 > ${prefix}
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
45
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
46 cat <<-END_VERSIONS > versions.yml
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
47 "${task.process}":
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
48 pigz: \$( pigz --version 2>&1 | sed 's/pigz //g' )
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
49 END_VERSIONS
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
50 """
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
51
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
52 stub:
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
53 def file_list = files_in.collect { it.toString() }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
54 prefix = task.ext.prefix ?: "${meta.id}${file_list[0].substring(file_list[0].lastIndexOf('.'))}"
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
55 """
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
56 touch $prefix
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
57
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
58 cat <<-END_VERSIONS > versions.yml
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
59 "${task.process}":
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
60 pigz: \$( pigz --version 2>&1 | sed 's/pigz //g' )
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
61 END_VERSIONS
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
62
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
63 catver=""
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
64 zver=""
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
65
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
66 if [ "${workflow.containerEngine}" != "null" ]; then
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
67 catver=\$( cat --help 2>&1 | sed -e '1!d; s/ (.*\$//' | cut -f1-2 -d' ' )
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
68 zver=\$( zcat --help 2>&1 | sed -e '1!d; s/ (.*\$//' )
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
69
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
70 else
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
71 catver=\$( cat --version 2>&1 | sed '1!d; s/^.*(GNU coreutils//; s/) //;' )
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
72 zver=\$( zcat --version 2>&1 | sed '1!d; s/^.*(gzip) //' )
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
73 fi
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
74
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
75 cat <<-END_VERSIONS >> versions.yml
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
76 cat: \$catver
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
77 zcat: \$zver
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
78 END_VERSIONS
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
79 """
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
80 }