-
Notifications
You must be signed in to change notification settings - Fork 0
/
nextflow.config
103 lines (93 loc) · 2.71 KB
/
nextflow.config
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
manifest {
author = 'Dan Fornika'
name = 'BCCDC-PHL/plasmid-assembly'
version = '0.1.2'
description = 'Nextflow pipeline for plasmid assembly'
mainScript = 'main.nf'
nextflowVersion = '>=20.01.0'
}
params {
prokka = false
bakta = false
bakta_db = '/data/ref_databases/bakta/latest'
db = '/data/ref_databases/plassembler/latest'
illumina_suffixes = ['*_R{1,2}_001', '*_R{1,2}', '*_{1,2}' ]
long_read_suffixes = ['*_RL', '*_L']
fastq_exts = ['.fastq.gz', '.fq.gz', '.fastq', '.fq']
fastq_search_path = makeFastqSearchPath(illumina_suffixes, fastq_exts)
fastq_input = 'NO_FILE'
long_reads_search_path = makeLongReadsSearchPath(long_read_suffixes, fastq_exts)
fastq_input_long = 'NO_FILE'
filtlong_min_length = 1000
filtlong_keep_percent = 90
chromosome_length = 1000000
samplesheet_input = 'NO_FILE'
versioned_outdir = false
collect_outputs = false
collected_outputs_prefix = 'collected'
pipeline_short_name = parsePipelineName(manifest.toMap().get('name'))
pipeline_minor_version = parseMinorVersion(manifest.toMap().get('version'))
}
def makeFastqSearchPath(illumina_suffixes, fastq_exts) {
def fastq_search_path = []
if (params.fastq_input.toString() != 'NO_FILE') {
for (suffix in illumina_suffixes) {
for (ext in fastq_exts) {
fastq_search_path.add(params.fastq_input.toString() + '/' + suffix.toString() + ext.toString())
}
}
}
return fastq_search_path
}
def makeLongReadsSearchPath(long_read_suffixes, fastq_exts) {
def fastq_search_path = []
if (params.fastq_input_long.toString() != 'NO_FILE') {
for (suffix in long_read_suffixes) {
for (ext in fastq_exts) {
fastq_search_path.add(params.fastq_input_long.toString() + '/' + suffix.toString() + ext.toString())
}
}
}
return fastq_search_path
}
def parseMinorVersion(version) {
minor_version = version.split('\\.')[0..1].join('.')
return minor_version
}
def parsePipelineName(name) {
short_name = name.split('/')[1]
return short_name
}
profiles {
conda {
conda.enabled = true
process.conda = "$baseDir/environments/environment.yml"
if (params.cache){
conda.cacheDir = params.cache
}
}
}
// Capture exit codes from upstream processes when piping
process.shell = ['/bin/bash', '-euo', 'pipefail']
process {
withName: quast {
cpus = 2
}
withName: fastp {
cpus = 4
}
withName: filtlong {
cpus = 12
}
withName: plassembler {
cpus = 16
conda = "$baseDir/environments/plassembler.yml"
}
withName: prokka {
cpus = 8
}
withName: bakta {
cpus = 12
conda = "$baseDir/environments/bakta.yml"
}
}