kkonganti@92: process { kkonganti@92: withName: 'SEQKIT_SEQ' { kkonganti@92: ext.args = [ kkonganti@92: params.fq_filter_by_len ? "-m ${params.fq_filter_by_len}" : '' kkonganti@92: ].join(' ').trim() kkonganti@92: } kkonganti@92: kkonganti@92: if (params.seqkit_grep_on) { kkonganti@92: withName: 'SEQKIT_GREP' { kkonganti@92: ext.args = addParamsToSummary( kkonganti@92: loadThisFunction("${params.toolshelp}${params.fs}seqkitgrep.nf").seqkitgrepHelp(params).helpparams kkonganti@92: ) kkonganti@92: } kkonganti@92: } kkonganti@92: kkonganti@92: withName: 'CENTRIFUGE_CLASSIFY' { kkonganti@92: ext.args = addParamsToSummary( kkonganti@92: loadThisFunction("${params.toolshelp}${params.fs}centrifuge.nf").centrifugeHelp(params).helpparams kkonganti@92: ) kkonganti@92: } kkonganti@92: kkonganti@92: withName: 'KRAKEN2_CLASSIFY' { kkonganti@92: ext.args = addParamsToSummary( kkonganti@92: loadThisFunction("${params.toolshelp}${params.fs}kraken2.nf").kraken2Help(params).helpparams kkonganti@92: ) kkonganti@92: } kkonganti@92: kkonganti@92: withName: 'MEGAHIT_ASSEMBLE' { kkonganti@92: ext.when = params.megahit_run kkonganti@92: errorStrategy = 'ignore' kkonganti@92: ext.args = addParamsToSummary( kkonganti@92: loadThisFunction("${params.toolshelp}${params.fs}megahit.nf").megahitHelp(params).helpparams kkonganti@92: ) kkonganti@92: } kkonganti@92: kkonganti@92: withName: 'SPADES_ASSEMBLE' { kkonganti@92: ext.when = params.spades_run kkonganti@92: errorStrategy = 'ignore' kkonganti@92: ext.args = addParamsToSummary( kkonganti@92: loadThisFunction("${params.toolshelp}${params.fs}spades.nf").spadesHelp(params).helpparams kkonganti@92: ) kkonganti@92: } kkonganti@92: kkonganti@92: if (params.ectyper_run) { kkonganti@92: withName: 'ECTYPER' { kkonganti@92: ext.when = params.ectyper_run kkonganti@92: ext.args = addParamsToSummary( kkonganti@92: loadThisFunction("${params.toolshelp}${params.fs}ectyper.nf").ectyperHelp(params).helpparams kkonganti@92: ) kkonganti@92: } kkonganti@92: } kkonganti@92: kkonganti@92: withName: 'SEROTYPEFINDER' { kkonganti@92: ext.when = params.serotypefinder_run kkonganti@92: ext.args = addParamsToSummary( kkonganti@92: loadThisFunction("${params.toolshelp}${params.fs}serotypefinder.nf").serotypefinderHelp(params).helpparams kkonganti@92: ) kkonganti@92: } kkonganti@92: kkonganti@92: withName: 'SEQSERO2' { kkonganti@92: ext.when = params.seqsero2_run kkonganti@92: ext.args = addParamsToSummary( kkonganti@92: loadThisFunction("${params.toolshelp}${params.fs}seqsero2.nf").seqsero2Help(params).helpparams kkonganti@92: ) kkonganti@92: } kkonganti@92: kkonganti@92: withName: 'MLST' { kkonganti@92: ext.when = params.mlst_run kkonganti@92: ext.args = addParamsToSummary( kkonganti@92: loadThisFunction("${params.toolshelp}${params.fs}mlst.nf").mlstHelp(params).helpparams kkonganti@92: ) kkonganti@92: } kkonganti@92: kkonganti@92: if (params.amrfinderplus_run) { kkonganti@92: withName: 'AMRFINDERPLUS_RUN' { kkonganti@92: ext.when = params.amrfinderplus_run kkonganti@92: ext.args = addParamsToSummary( kkonganti@92: loadThisFunction("${params.toolshelp}${params.fs}amrfinderplus.nf").amrfinderplusHelp(params).helpparams kkonganti@92: ) kkonganti@92: } kkonganti@92: } kkonganti@92: kkonganti@92: withName: 'ABRICATE_RUN' { kkonganti@92: ext.when = params.abricate_run kkonganti@92: ext.args = addParamsToSummary( kkonganti@92: loadThisFunction("${params.toolshelp}${params.fs}abricate.nf").abricateHelp(params).helpparams kkonganti@92: ) kkonganti@92: } kkonganti@92: kkonganti@92: withName: 'ABRICATE_SUMMARY' { kkonganti@92: ext.when = params.abricate_summary_run kkonganti@92: } kkonganti@92: } kkonganti@92: kkonganti@92: // Method to instantiate a new function parser kkonganti@92: // Need to refactor using ScriptParser... another day kkonganti@92: def loadThisFunction (func_file) { kkonganti@92: GroovyShell grvy_sh = new GroovyShell() kkonganti@92: def func = grvy_sh.parse(new File ( func_file ) ) kkonganti@92: return func kkonganti@92: } kkonganti@92: kkonganti@92: // Method to add relevant final parameters to summary log kkonganti@92: def addParamsToSummary(Map params_to_add = [:]) { kkonganti@92: kkonganti@92: if (!params_to_add.isEmpty()) { kkonganti@92: def not_null_params_to_add = params_to_add.findAll { kkonganti@92: it.value.clivalue != null && kkonganti@92: it.value.clivalue != '[:]' && kkonganti@92: it.value.clivalue != '' kkonganti@92: } kkonganti@92: kkonganti@92: params.logtheseparams += not_null_params_to_add.keySet().toList() kkonganti@92: kkonganti@92: return not_null_params_to_add.collect { kkonganti@92: "${it.value.cliflag} ${it.value.clivalue.toString().replaceAll(/(?:^\s+|\s+$)/, '')}" kkonganti@92: }.join(' ').trim() kkonganti@92: } kkonganti@92: return 1 kkonganti@92: }