annotate 1.0.0/conf/modules.config @ 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 {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
2 publishDir = [
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
3 path: {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
4 "${task.process.tokenize(':')[-1].toLowerCase()}" == "multiqc" ?
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
5 "${params.output}${params.fs}${params.pipeline.toLowerCase()}-${task.process.tokenize(':')[-1].toLowerCase()}" :
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
6 "${params.output}${params.fs}${task.process.tokenize(':')[-1].toLowerCase()}"
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
7 },
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
8 mode: params.publish_dir_mode,
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
9 overwrite: params.publish_dir_overwrite,
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
10 saveAs: { filename -> filename =~ /^versions\.yml|genome_paths\.txt|[bettercallsalbcs].+?_mqc.*/ ? null : filename }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
11 ]
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
12
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
13 errorStrategy = {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
14 ![0].contains(task.exitStatus) ? dynamic_retry(task.attempt, 10) : 'finish'
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
15 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
16
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
17 maxRetries = 1
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
18 resourceLabels = {[
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
19 process: task.process,
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
20 memoryRequested: task.memory.toString(),
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
21 cpusRequested: task.cpus.toString()
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
22 ]}
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
23
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
24 withLabel: 'process_femto' {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
25 cpus = { 1 * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
26 memory = { 1.GB * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
27 time = { 1.h * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
28 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
29
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
30 withLabel: 'process_pico' {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
31 cpus = { min_cpus(2) * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
32 memory = { 4.GB * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
33 time = { 2.h * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
34 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
35
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
36 withLabel: 'process_nano' {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
37 cpus = { min_cpus(4) * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
38 memory = { 8.GB * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
39 time = { 4.h * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
40 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
41
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
42 withLabel: 'process_micro' {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
43 cpus = { min_cpus(8) * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
44 memory = { 16.GB * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
45 time = { 8.h * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
46 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
47
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
48 withLabel: 'process_only_mem_low' {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
49 cpus = { 1 * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
50 memory = { 60.GB * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
51 time = { 20.h * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
52 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
53
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
54 withLabel: 'process_only_mem_medium' {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
55 cpus = { 1 * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
56 memory = { 100.GB * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
57 time = { 30.h * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
58 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
59
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
60 withLabel: 'process_only_mem_high' {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
61 cpus = { 1 * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
62 memory = { 128.GB * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
63 time = { 60.h * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
64 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
65
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
66 withLabel: 'process_low' {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
67 cpus = { min_cpus(10) * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
68 memory = { 60.GB * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
69 time = { 20.h * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
70 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
71
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
72 withLabel: 'process_medium' {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
73 cpus = { min_cpus(10) * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
74 memory = { 100.GB * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
75 time = { 30.h * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
76 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
77
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
78 withLabel: 'process_high' {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
79 cpus = { min_cpus(10) * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
80 memory = { 128.GB * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
81 time = { 60.h * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
82 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
83
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
84 withLabel: 'process_higher' {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
85 cpus = { min_cpus(10) * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
86 memory = { 256.GB * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
87 time = { 60.h * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
88 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
89
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
90 withLabel: 'process_gigantic' {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
91 cpus = { min_cpus(10) * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
92 memory = { 512.GB * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
93 time = { 60.h * task.attempt }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
94 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
95 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
96
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
97 if ( ( ( params.input || params.metadata ) && params.pipeline ) ||
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
98 ( params.pipeline.toString().equalsIgnoreCase('bettercallsal_db') && params.output) ) {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
99 try {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
100 includeConfig "${params.workflowsconf}${params.fs}process${params.fs}${params.pipeline}.process.config"
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
101 } catch (Exception e) {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
102 System.err.println('-'.multiply(params.linewidth) + "\n" +
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
103 "\033[0;31m${params.cfsanpipename} - ERROR\033[0m\n" +
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
104 '-'.multiply(params.linewidth) + "\n" + "\033[0;31mCould not load " +
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
105 "default pipeline's process configuration. Please provide a pipeline \n" +
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
106 "name using the --pipeline option.\n\033[0m" + '-'.multiply(params.linewidth) + "\n")
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
107 System.exit(1)
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
108 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
109 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
110
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
111 // Function will return after sleeping for some time.
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
112 // Sleep time increases exponentially by task attempt.
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
113 def dynamic_retry(task_retry_num, factor_by) {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
114 // sleep(Math.pow(2, task_retry_num.toInteger()) * factor_by.toInteger() as long)
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
115 sleep(Math.pow(1.27, task_retry_num.toInteger()) as long)
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
116 return 'retry'
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
117 }
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
118
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
119 // Function that will adjust the minimum number of CPU
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
120 // cores depending as requested by the user.
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
121 def min_cpus(cores) {
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
122 return Math.min(cores as int, "${params.max_cpus}" as int)
801b85b03a17 planemo upload
galaxytrakr
parents:
diff changeset
123 }