From 7380cae49bf0ae5092c75d7f2661ac84d0dbfb55 Mon Sep 17 00:00:00 2001 From: Piotr Konopka Date: Tue, 1 Oct 2024 15:41:38 +0200 Subject: [PATCH] DPL: Remove use of obsolete reconfiguration mechanism in ECS (#13539) --- .../Core/include/Framework/O2ControlLabels.h | 4 --- Framework/Core/src/O2ControlHelpers.cxx | 30 ------------------- Framework/Core/src/O2ControlLabels.cxx | 1 - 3 files changed, 35 deletions(-) diff --git a/Framework/Core/include/Framework/O2ControlLabels.h b/Framework/Core/include/Framework/O2ControlLabels.h index 2d4ea7c66cc3a..eb05f156cf58d 100644 --- a/Framework/Core/include/Framework/O2ControlLabels.h +++ b/Framework/Core/include/Framework/O2ControlLabels.h @@ -31,10 +31,6 @@ const extern DataProcessorLabel uniqueProxyLabel; // Thus, AliECS will not perform host and port allocation automatically. It takes priority over `uniqueProxyLabel`. const extern DataProcessorLabel preserveRawChannelsLabel; -// This label makes AliECS templates add the property `qcConfiguration` to the tasks, allowing them -// to reconfigure in init with a freshly templated config. -const extern DataProcessorLabel qcReconfigurable; - } // namespace ecs } // namespace o2::framework diff --git a/Framework/Core/src/O2ControlHelpers.cxx b/Framework/Core/src/O2ControlHelpers.cxx index 46b1eb12ea26a..48d564e4ee4f0 100644 --- a/Framework/Core/src/O2ControlHelpers.cxx +++ b/Framework/Core/src/O2ControlHelpers.cxx @@ -207,11 +207,6 @@ bool shouldPreserveRawChannels(const DeviceSpec& spec) return std::find(spec.labels.begin(), spec.labels.end(), ecs::preserveRawChannelsLabel) != spec.labels.end(); } -bool isQcReconfigurable(const DeviceSpec& spec) -{ - return std::find(spec.labels.begin(), spec.labels.end(), ecs::qcReconfigurable) != spec.labels.end(); -} - bool isCritical(const DeviceSpec& spec) { // DPL's expendable Data Processor corresponds to a non-critical task in ECS @@ -220,27 +215,6 @@ bool isCritical(const DeviceSpec& spec) return std::find(spec.labels.begin(), spec.labels.end(), DataProcessorLabel{"expendable"}) == spec.labels.end(); } -void dumpProperties(std::ostream& dumpOut, const DeviceExecution& execution, const DeviceSpec& spec, const std::string& indLevel) -{ - // get the argument `--config` - std::string configPath; - auto it = std::find_if(execution.args.begin(), execution.args.end(), [](char* v) { return v != nullptr && strcmp(v, "--config") == 0; }); - - // get the next argument and find `/o2/components/` in it, then take what comes after in the string. - if (it != execution.args.end()) { - std::string configParam = *(++it); - std::string prefix = "/o2/components/"; // keep only the path to the config file, i.e. stuff after "/o2/components/" - size_t pos = configParam.find(prefix); - if (pos != std::string::npos) { - configPath = configParam.substr(pos + prefix.length()); - } - } - - dumpOut << indLevel << "properties:\n"; - std::string qcConfigFullCommand = configPath.empty() ? "\"\"" : "\"{{ ToPtree(config.Get('" + configPath + "'), 'json') }}\""; - dumpOut << indLevel << indScheme << "qcConfiguration: " << qcConfigFullCommand << "\n"; -} - void dumpCommand(std::ostream& dumpOut, const DeviceExecution& execution, std::string indLevel) { dumpOut << indLevel << "shell: true\n"; @@ -461,10 +435,6 @@ void dumpTask(std::ostream& dumpOut, const DeviceSpec& spec, const DeviceExecuti } } - if (implementation::isQcReconfigurable(spec)) { - implementation::dumpProperties(dumpOut, execution, spec, indLevel); - } - dumpOut << indLevel << "command:\n"; implementation::dumpCommand(dumpOut, execution, indLevel + indScheme); } diff --git a/Framework/Core/src/O2ControlLabels.cxx b/Framework/Core/src/O2ControlLabels.cxx index 9c0b4dbd96d41..aa22d858f6e44 100644 --- a/Framework/Core/src/O2ControlLabels.cxx +++ b/Framework/Core/src/O2ControlLabels.cxx @@ -16,5 +16,4 @@ namespace o2::framework::ecs const DataProcessorLabel uniqueProxyLabel = {"ecs-unique-proxy"}; const DataProcessorLabel preserveRawChannelsLabel = {"ecs-preserve-raw-channels"}; -const DataProcessorLabel qcReconfigurable = {"qc-reconfigurable"}; } \ No newline at end of file