2020-06-18 16:54:14 +01:00
|
|
|
#!/usr/bin/env nextflow
|
|
|
|
|
|
|
|
// Specify DSL2
|
|
|
|
nextflow.preview.dsl = 2
|
|
|
|
|
|
|
|
// Process definition
|
|
|
|
process umitools_dedup {
|
2020-06-26 09:06:37 +01:00
|
|
|
publishDir "${params.outdir}/umitools/dedup",
|
2020-06-18 16:54:14 +01:00
|
|
|
mode: "copy", overwrite: true
|
|
|
|
|
|
|
|
container 'luslab/nf-modules-umitools:latest'
|
|
|
|
|
|
|
|
input:
|
2020-06-26 08:36:11 +01:00
|
|
|
tuple val(sample_id), path(bam)
|
2020-07-11 13:42:13 +02:00
|
|
|
|
2020-06-18 16:54:14 +01:00
|
|
|
output:
|
2020-06-26 09:04:15 +01:00
|
|
|
tuple val(sample_id), path("${sample_id}.dedup.bam"), emit: dedupBam
|
|
|
|
tuple val(sample_id), path("${sample_id}.dedup.bam.bai"), emit: dedupBai
|
2020-06-26 08:22:43 +01:00
|
|
|
path "*.dedup.log", emit: report
|
2020-06-18 16:54:14 +01:00
|
|
|
|
2020-06-26 08:19:54 +01:00
|
|
|
script:
|
2020-06-18 16:54:14 +01:00
|
|
|
|
|
|
|
// Init
|
2020-06-23 09:34:47 +01:00
|
|
|
args = "--log=${sample_id}.dedup.log"
|
2020-06-18 16:54:14 +01:00
|
|
|
|
|
|
|
// Check main args string exists and strip whitespace
|
|
|
|
if(params.umitools_dedup_args) {
|
2020-06-19 15:55:45 +01:00
|
|
|
ext_args = params.umitools_dedup_args
|
2020-06-26 08:36:11 +01:00
|
|
|
args += " " + ext_args.trim()
|
2020-06-18 16:54:14 +01:00
|
|
|
}
|
2020-06-19 15:55:45 +01:00
|
|
|
|
|
|
|
// Contruct CL line
|
2020-06-26 09:04:15 +01:00
|
|
|
dedup_command = "umi_tools dedup ${args} -I ${bam[0]} -S ${sample_id}.dedup.bam --output-stats=${sample_id}"
|
2020-06-19 15:55:45 +01:00
|
|
|
|
|
|
|
// Log
|
|
|
|
if (params.verbose){
|
2020-06-26 09:04:15 +01:00
|
|
|
println ("[MODULE] umi_tools/dedup command: " + dedup_command)
|
2020-06-18 16:54:14 +01:00
|
|
|
}
|
|
|
|
|
2020-06-19 08:21:55 +01:00
|
|
|
//SHELL
|
2020-06-18 16:54:14 +01:00
|
|
|
"""
|
2020-06-26 09:04:15 +01:00
|
|
|
${dedup_command}
|
|
|
|
samtools index ${sample_id}.dedup.bam
|
2020-06-18 16:54:14 +01:00
|
|
|
"""
|
2020-06-23 09:34:47 +01:00
|
|
|
}
|