mirror of
https://github.com/MillironX/nf-core_modules.git
synced 2025-01-18 10:56:13 -05:00
ae48653bd2
* fix: remove left-over unnecessary code * Make summary output optional as not generated if no sufficiently HQ bins found * Make contig2bin optional as only generated if sufficient HQ bins found
62 lines
2.6 KiB
Text
62 lines
2.6 KiB
Text
process DASTOOL_DASTOOL {
|
|
tag "$meta.id"
|
|
label 'process_medium'
|
|
|
|
conda (params.enable_conda ? "bioconda::das_tool=1.1.4" : null)
|
|
container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ?
|
|
'https://depot.galaxyproject.org/singularity/das_tool:1.1.4--r41hdfd78af_1' :
|
|
'quay.io/biocontainers/das_tool:1.1.4--r41hdfd78af_1' }"
|
|
|
|
input:
|
|
tuple val(meta), path(contigs), path(bins)
|
|
path(proteins)
|
|
path(db_directory)
|
|
|
|
output:
|
|
tuple val(meta), path("*.log") , emit: log
|
|
tuple val(meta), path("*_summary.tsv") , optional: true, emit: summary
|
|
tuple val(meta), path("*_DASTool_contig2bin.tsv") , optional: true, emit: contig2bin
|
|
tuple val(meta), path("*.eval") , optional: true, emit: eval
|
|
tuple val(meta), path("*_DASTool_bins/*.fa") , optional: true, emit: bins
|
|
tuple val(meta), path("*.pdf") , optional: true, emit: pdfs
|
|
tuple val(meta), path("*.candidates.faa") , optional: true, emit: fasta_proteins
|
|
tuple val(meta), path("*.faa") , optional: true, emit: candidates_faa
|
|
tuple val(meta), path("*.archaea.scg") , optional: true, emit: fasta_archaea_scg
|
|
tuple val(meta), path("*.bacteria.scg") , optional: true, emit: fasta_bacteria_scg
|
|
tuple val(meta), path("*.b6") , optional: true, emit: b6
|
|
tuple val(meta), path("*.seqlength") , optional: true, emit: seqlength
|
|
path "versions.yml" , emit: versions
|
|
|
|
when:
|
|
task.ext.when == null || task.ext.when
|
|
|
|
script:
|
|
def args = task.ext.args ?: ''
|
|
def prefix = task.ext.prefix ?: "${meta.id}"
|
|
def bin_list = bins instanceof List ? bins.join(",") : "$bins"
|
|
def db_dir = db_directory ? "--db_directory $db_directory" : ""
|
|
def clean_contigs = contigs.toString() - ".gz"
|
|
def decompress_contigs = contigs.toString() == clean_contigs ? "" : "gunzip -q -f $contigs"
|
|
def clean_proteins = proteins ? proteins.toString() - ".gz" : ""
|
|
def decompress_proteins = proteins ? "gunzip -f $proteins" : ""
|
|
def proteins_pred = proteins ? "-p $clean_proteins" : ""
|
|
|
|
"""
|
|
$decompress_proteins
|
|
$decompress_contigs
|
|
|
|
DAS_Tool \\
|
|
$args \\
|
|
$proteins_pred \\
|
|
$db_dir \\
|
|
-t $task.cpus \\
|
|
-i $bin_list \\
|
|
-c $clean_contigs \\
|
|
-o $prefix
|
|
|
|
cat <<-END_VERSIONS > versions.yml
|
|
"${task.process}":
|
|
dastool: \$( DAS_Tool --version 2>&1 | grep "DAS Tool" | sed 's/DAS Tool //' )
|
|
END_VERSIONS
|
|
"""
|
|
}
|