kkonganti@0: process TABLE_SUMMARY { kkonganti@0: tag "$table_sum_on" kkonganti@0: label 'process_micro' kkonganti@0: kkonganti@0: // Requires `pyyaml` which does not have a dedicated container but is in the MultiQC container kkonganti@0: module (params.enable_module ? "${params.swmodulepath}${params.fs}python${params.fs}3.8.1" : null) kkonganti@0: conda (params.enable_conda ? "conda-forge::python=3.9 conda-forge::pyyaml conda-forge::coreutils" : null) kkonganti@0: container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ? kkonganti@0: 'https://depot.galaxyproject.org/singularity/multiqc:1.14--pyhdfd78af_0' : kkonganti@0: 'quay.io/biocontainers/multiqc:1.14--pyhdfd78af_0' }" kkonganti@0: kkonganti@0: input: kkonganti@0: tuple val(table_sum_on), path(tables) kkonganti@0: kkonganti@0: output: kkonganti@0: tuple val(table_sum_on), path("*.tblsum.txt"), emit: tblsummed kkonganti@0: path "*_mqc.yml" , emit: mqc_yml kkonganti@0: path "versions.yml" , emit: versions kkonganti@0: kkonganti@0: when: kkonganti@0: task.ext.when == null || task.ext.when || tables kkonganti@0: kkonganti@0: script: kkonganti@0: def args = task.ext.args ?: '' kkonganti@0: def onthese = tables.collect().join('\\n') kkonganti@0: """ kkonganti@0: filenum="1" kkonganti@0: header="" kkonganti@0: kkonganti@0: echo -e "$onthese" | while read -r file; do kkonganti@0: kkonganti@0: if [ "\${filenum}" == "1" ]; then kkonganti@0: header=\$( head -n1 "\${file}" ) kkonganti@0: echo -e "\${header}" > ${table_sum_on}.tblsum.txt kkonganti@0: fi kkonganti@0: kkonganti@0: tail -n+2 "\${file}" >> ${table_sum_on}.tblsum.txt kkonganti@0: kkonganti@0: filenum=\$((filenum+1)) kkonganti@0: done kkonganti@0: kkonganti@0: create_mqc_data_table.py $table_sum_on kkonganti@0: kkonganti@0: cat <<-END_VERSIONS > versions.yml kkonganti@0: "${task.process}": kkonganti@0: bash: \$( bash --version 2>&1 | sed '1!d; s/^.*version //; s/ (.*\$//' ) kkonganti@0: python: \$( python --version | sed 's/Python //g' ) kkonganti@0: END_VERSIONS kkonganti@0: kkonganti@0: headver=\$( head --version 2>&1 | sed '1!d; s/^.*(GNU coreutils//; s/) //;' ) kkonganti@0: tailver=\$( tail --version 2>&1 | sed '1!d; s/^.*(GNU coreutils//; s/) //;' ) kkonganti@0: kkonganti@0: cat <<-END_VERSIONS >> versions.yml kkonganti@0: head: \$headver kkonganti@0: tail: \$tailver kkonganti@0: END_VERSIONS kkonganti@0: """ kkonganti@0: }