mirror of
https://github.com/MillironX/nf-core_modules.git
synced 2025-01-10 07:41:11 -05:00
c8168bc351
* Update LAST to version 1238. * Update functions.nf to the latest devel version. * Update test MD5sums after updating software version. * Make portable on MacOS * Allow input alignments to be uncompressed. While the strategy in this family of modules is to make all inputs and outputs compressed, this change might be useful to some users. As of LAST 2138, `last/split` does not allow its input to be compressed. * Search for .des file, that is guaranteed to be unique. Some LAST indexes have more than one .bck file and it makes the name detection crash. In this commit, I also standardise how the names are detected. * Use value input channel and optional output channels to handle formats. As discussed on Slack, it is preferred to use a value input channel instead of sneaking options through `params.args2` or `params.format` as we did. Likewise, optional output channels with clearly labeled format are preferred to 'catch-all' wildcards.
47 lines
2 KiB
Text
47 lines
2 KiB
Text
// Import generic module functions
|
|
include { initOptions; saveFiles; getSoftwareName } from './functions'
|
|
|
|
params.options = [:]
|
|
options = initOptions(params.options)
|
|
|
|
process LAST_MAFCONVERT {
|
|
tag "$meta.id"
|
|
label 'process_high'
|
|
publishDir "${params.outdir}",
|
|
mode: params.publish_dir_mode,
|
|
saveAs: { filename -> saveFiles(filename:filename, options:params.options, publish_dir:getSoftwareName(task.process), meta:meta, publish_by_meta:['id']) }
|
|
|
|
conda (params.enable_conda ? "bioconda::last=1238" : null)
|
|
if (workflow.containerEngine == 'singularity' && !params.singularity_pull_docker_container) {
|
|
container "https://depot.galaxyproject.org/singularity/last:1238--h2e03b76_0"
|
|
} else {
|
|
container "quay.io/biocontainers/last:1238--h2e03b76_0"
|
|
}
|
|
|
|
input:
|
|
tuple val(meta), path(maf)
|
|
val(format)
|
|
|
|
output:
|
|
tuple val(meta), path("*.axt.gz"), optional:true, emit: axt_gz
|
|
tuple val(meta), path("*.blast.gz"), optional:true, emit: blast_gz
|
|
tuple val(meta), path("*.blasttab.gz"), optional:true, emit: blasttab_gz
|
|
tuple val(meta), path("*.chain.gz"), optional:true, emit: chain_gz
|
|
tuple val(meta), path("*.gff.gz"), optional:true, emit: gff_gz
|
|
tuple val(meta), path("*.html.gz"), optional:true, emit: html_gz
|
|
tuple val(meta), path("*.psl.gz"), optional:true, emit: psl_gz
|
|
tuple val(meta), path("*.sam.gz"), optional:true, emit: sam_gz
|
|
tuple val(meta), path("*.tab.gz"), optional:true, emit: tab_gz
|
|
path "*.version.txt" , emit: version
|
|
|
|
script:
|
|
def software = getSoftwareName(task.process)
|
|
def prefix = options.suffix ? "${meta.id}${options.suffix}" : "${meta.id}"
|
|
"""
|
|
maf-convert $options.args $format $maf | gzip --no-name \\
|
|
> ${prefix}.${format}.gz
|
|
|
|
# maf-convert has no --version option but lastdb (part of the same package) has.
|
|
echo \$(lastdb --version 2>&1) | sed 's/lastdb //' > ${software}.version.txt
|
|
"""
|
|
}
|