kkonganti@105: process SEQKIT_GREP { kkonganti@105: tag "$meta.id" kkonganti@105: label 'process_low' kkonganti@105: kkonganti@105: module (params.enable_module ? "${params.swmodulepath}${params.fs}seqkit${params.fs}2.2.0" : null) kkonganti@105: conda (params.enable_conda ? "bioconda::seqkit=2.2.0 conda-forge::sed=4.7 conda-forge::coreutils" : null) kkonganti@105: container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ? kkonganti@105: 'https://depot.galaxyproject.org/singularity/seqkit:2.1.0--h9ee0642_0': kkonganti@105: 'quay.io/biocontainers/seqkit:2.1.0--h9ee0642_0' }" kkonganti@105: kkonganti@105: input: kkonganti@105: tuple val(meta), path(reads), path(pattern_file) kkonganti@105: kkonganti@105: output: kkonganti@105: tuple val(meta), path("*.gz"), emit: fastx kkonganti@105: path "versions.yml" , emit: versions kkonganti@105: kkonganti@105: when: kkonganti@105: task.ext.when == null || task.ext.when kkonganti@105: kkonganti@105: script: kkonganti@105: def args = task.ext.args ?: '' kkonganti@105: def prefix = task.ext.prefix ?: "${meta.id}" kkonganti@105: kkonganti@105: def extension = "fastq" kkonganti@105: if ("$reads" ==~ /.+\.fasta|.+\.fasta.gz|.+\.fa|.+\.fa.gz|.+\.fas|.+\.fas.gz|.+\.fna|.+\.fna.gz/) { kkonganti@105: extension = "fasta" kkonganti@105: } kkonganti@105: kkonganti@105: if (meta.single_end) { kkonganti@105: """ kkonganti@105: pattern_file_contents=\$(sed '1!d' $pattern_file) kkonganti@105: if [ "\$pattern_file_contents" != "DuMmY" ]; then kkonganti@105: additional_args="-f $pattern_file $args" kkonganti@105: else kkonganti@105: additional_args="$args" kkonganti@105: fi kkonganti@105: kkonganti@105: seqkit \\ kkonganti@105: grep \\ kkonganti@105: -j $task.cpus \\ kkonganti@105: -o ${prefix}.seqkit-grep.${extension}.gz \\ kkonganti@105: \$additional_args \\ kkonganti@105: $reads kkonganti@105: kkonganti@105: cat <<-END_VERSIONS > versions.yml kkonganti@105: "${task.process}": kkonganti@105: seqkit: \$( seqkit | sed '3!d; s/Version: //' ) kkonganti@105: END_VERSIONS kkonganti@105: """ kkonganti@105: } else { kkonganti@105: """ kkonganti@105: pattern_file_contents=\$(sed '1!d' $pattern_file) kkonganti@105: if [ "\$pattern_file_contents" != "DuMmY" ]; then kkonganti@105: additional_args="-f $pattern_file $args" kkonganti@105: else kkonganti@105: additional_args="$args" kkonganti@105: fi kkonganti@105: kkonganti@105: seqkit \\ kkonganti@105: grep \\ kkonganti@105: -j $task.cpus \\ kkonganti@105: -o ${prefix}.R1.seqkit-grep.${extension}.gz \\ kkonganti@105: \$additional_args \\ kkonganti@105: ${reads[0]} kkonganti@105: kkonganti@105: seqkit \\ kkonganti@105: grep \\ kkonganti@105: -j $task.cpus \\ kkonganti@105: -o ${prefix}.R2.seqkit-grep.${extension}.gz \\ kkonganti@105: \$additional_args \\ kkonganti@105: ${reads[1]} kkonganti@105: kkonganti@105: seqkit \\ kkonganti@105: pair \\ kkonganti@105: -j $task.cpus \\ kkonganti@105: -1 ${prefix}.R1.seqkit-grep.${extension}.gz \\ kkonganti@105: -2 ${prefix}.R2.seqkit-grep.${extension}.gz kkonganti@105: kkonganti@105: rm ${prefix}.R1.seqkit-grep.${extension}.gz kkonganti@105: rm ${prefix}.R2.seqkit-grep.${extension}.gz kkonganti@105: kkonganti@105: cat <<-END_VERSIONS > versions.yml kkonganti@105: "${task.process}": kkonganti@105: seqkit: \$( seqkit | sed '3!d; s/Version: //' ) kkonganti@105: END_VERSIONS kkonganti@105: """ kkonganti@105: } kkonganti@105: }