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