From 3ddc212777d35e1b81bdb8bd320b2b78aa0a1c81 Mon Sep 17 00:00:00 2001 From: tmadlener Date: Fri, 17 Nov 2023 11:56:01 +0100 Subject: [PATCH] Merge PodioDataSvc into k4DataSvc - Move k4DataSvc to core library - Make PodioDataSvc an alias for now - Remove FCCDataSvc --- k4FWCore/CMakeLists.txt | 8 +- k4FWCore/components/FCCDataSvc.cpp | 33 ----- k4FWCore/components/FCCDataSvc.h | 34 ----- k4FWCore/components/PodioInput.h | 4 +- k4FWCore/components/PodioOutput.h | 4 +- k4FWCore/components/k4DataSvc.cpp | 31 +---- k4FWCore/components/k4DataSvc.h | 33 ----- k4FWCore/include/k4FWCore/PodioDataSvc.h | 129 +----------------- k4FWCore/include/k4FWCore/k4DataSvc.h | 120 ++++++++++++++++ .../src/{PodioDataSvc.cpp => k4DataSvc.cpp} | 51 +++---- 10 files changed, 162 insertions(+), 285 deletions(-) delete mode 100644 k4FWCore/components/FCCDataSvc.cpp delete mode 100644 k4FWCore/components/FCCDataSvc.h delete mode 100644 k4FWCore/components/k4DataSvc.h create mode 100644 k4FWCore/include/k4FWCore/k4DataSvc.h rename k4FWCore/src/{PodioDataSvc.cpp => k4DataSvc.cpp} (80%) diff --git a/k4FWCore/CMakeLists.txt b/k4FWCore/CMakeLists.txt index 495712d2..f0b2438f 100644 --- a/k4FWCore/CMakeLists.txt +++ b/k4FWCore/CMakeLists.txt @@ -29,10 +29,10 @@ gaudi_install(PYTHON) gaudi_add_library(k4FWCore - SOURCES src/PodioDataSvc.cpp - src/PodioLegacyDataSvc.cpp - src/KeepDropSwitch.cpp - LINK Gaudi::GaudiAlgLib Gaudi::GaudiKernel podio::podioRootIO ROOT::Core ROOT::RIO ROOT::Tree + SOURCES src/k4DataSvc.cpp + src/PodioLegacyDataSvc.cpp + src/KeepDropSwitch.cpp + LINK Gaudi::GaudiAlgLib Gaudi::GaudiKernel podio::podioRootIO ROOT::Core ROOT::RIO ROOT::Tree ) target_include_directories(k4FWCore PUBLIC $ diff --git a/k4FWCore/components/FCCDataSvc.cpp b/k4FWCore/components/FCCDataSvc.cpp deleted file mode 100644 index 275a780e..00000000 --- a/k4FWCore/components/FCCDataSvc.cpp +++ /dev/null @@ -1,33 +0,0 @@ -/* - * Copyright (c) 2014-2023 Key4hep-Project. - * - * This file is part of Key4hep. - * See https://key4hep.github.io/key4hep-doc/ for further info. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -#include "FCCDataSvc.h" - -// Instantiation of a static factory class used by clients to create -// instances of this service -DECLARE_COMPONENT(FCCDataSvc) - -/// Standard Constructor -FCCDataSvc::FCCDataSvc(const std::string& name, ISvcLocator* svc) : PodioDataSvc(name, svc) { - declareProperty("inputs", m_filenames = {}, "Names of the files to read"); - declareProperty("input", m_filename = "", "Name of the file to read"); -} - -/// Standard Destructor -FCCDataSvc::~FCCDataSvc() {} diff --git a/k4FWCore/components/FCCDataSvc.h b/k4FWCore/components/FCCDataSvc.h deleted file mode 100644 index 4941e9e2..00000000 --- a/k4FWCore/components/FCCDataSvc.h +++ /dev/null @@ -1,34 +0,0 @@ -/* - * Copyright (c) 2014-2023 Key4hep-Project. - * - * This file is part of Key4hep. - * See https://key4hep.github.io/key4hep-doc/ for further info. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -#ifndef K4FWCORE_FCCDATASVC_H -#define K4FWCORE_FCCDATASVC_H - -#include "k4FWCore/PodioDataSvc.h" - -/// an alias to k4DataSvc for backwards compatibility -class FCCDataSvc : public PodioDataSvc { -public: - /// Standard Constructor - FCCDataSvc(const std::string& name, ISvcLocator* svc); - - /// Standard Destructor - virtual ~FCCDataSvc(); -}; -#endif diff --git a/k4FWCore/components/PodioInput.h b/k4FWCore/components/PodioInput.h index 978d821e..13acb451 100644 --- a/k4FWCore/components/PodioInput.h +++ b/k4FWCore/components/PodioInput.h @@ -26,7 +26,7 @@ #include #include -class PodioDataSvc; +class k4DataSvc; /** @class PodioInput * @@ -49,7 +49,7 @@ class PodioInput final : public Gaudi::Functional::Consumer Gaudi::Property> m_collectionNames{ this, "collections", {}, "Collections that should be read (default all)"}; // Data service: needed to register objects and get collection IDs. Just an observing pointer. - PodioDataSvc* m_podioDataSvc; + k4DataSvc* m_podioDataSvc; mutable std::map> m_readers; }; diff --git a/k4FWCore/components/PodioOutput.h b/k4FWCore/components/PodioOutput.h index 4fa62c2b..c177d819 100644 --- a/k4FWCore/components/PodioOutput.h +++ b/k4FWCore/components/PodioOutput.h @@ -27,7 +27,7 @@ #include // forward declarations -class PodioDataSvc; +class k4DataSvc; class PodioOutput : public GaudiAlgorithm { public: @@ -54,7 +54,7 @@ class PodioOutput : public GaudiAlgorithm { "An optional file path to copy the outputfile to."}; /// Switch for keeping or dropping outputs KeepDropSwitch m_switch; - PodioDataSvc* m_podioDataSvc; + k4DataSvc* m_podioDataSvc; /// The actual ROOT frame writer std::unique_ptr m_framewriter; /// The stored collections diff --git a/k4FWCore/components/k4DataSvc.cpp b/k4FWCore/components/k4DataSvc.cpp index 380634a3..3c06c72a 100644 --- a/k4FWCore/components/k4DataSvc.cpp +++ b/k4FWCore/components/k4DataSvc.cpp @@ -1,34 +1,5 @@ -/* - * Copyright (c) 2014-2023 Key4hep-Project. - * - * This file is part of Key4hep. - * See https://key4hep.github.io/key4hep-doc/ for further info. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -#include "k4DataSvc.h" +#include "k4FWCore/k4DataSvc.h" // Instantiation of a static factory class used by clients to create // instances of this service DECLARE_COMPONENT(k4DataSvc) - -/// Standard Constructor -k4DataSvc::k4DataSvc(const std::string& name, ISvcLocator* svc) : PodioDataSvc(name, svc) { - declareProperty("inputs", m_filenames = {}, "Names of the files to read"); - declareProperty("input", m_filename = "", "Name of the file to read"); - declareProperty("FirstEventEntry", m_1stEvtEntry = 0, "First event to read"); -} - -/// Standard Destructor -k4DataSvc::~k4DataSvc() {} diff --git a/k4FWCore/components/k4DataSvc.h b/k4FWCore/components/k4DataSvc.h deleted file mode 100644 index 4be2c04b..00000000 --- a/k4FWCore/components/k4DataSvc.h +++ /dev/null @@ -1,33 +0,0 @@ -/* - * Copyright (c) 2014-2023 Key4hep-Project. - * - * This file is part of Key4hep. - * See https://key4hep.github.io/key4hep-doc/ for further info. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -#ifndef K4FWCORE_K4DATASVC_H -#define K4FWCORE_K4DATASVC_H - -#include "k4FWCore/PodioDataSvc.h" - -class k4DataSvc : public PodioDataSvc { -public: - /// Standard Constructor - k4DataSvc(const std::string& name, ISvcLocator* svc); - - /// Standard Destructor - virtual ~k4DataSvc(); -}; -#endif diff --git a/k4FWCore/include/k4FWCore/PodioDataSvc.h b/k4FWCore/include/k4FWCore/PodioDataSvc.h index af5a892e..0cd20b91 100644 --- a/k4FWCore/include/k4FWCore/PodioDataSvc.h +++ b/k4FWCore/include/k4FWCore/PodioDataSvc.h @@ -1,127 +1,8 @@ -/* - * Copyright (c) 2014-2023 Key4hep-Project. - * - * This file is part of Key4hep. - * See https://key4hep.github.io/key4hep-doc/ for further info. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -#ifndef FWCORE_PODIODATASVC_H -#define FWCORE_PODIODATASVC_H +#ifndef K4FWCORE_PODIODATASVC_H +#define K4FWCORE_PODIODATASVC_H -#include "GaudiKernel/DataSvc.h" -#include "GaudiKernel/IConversionSvc.h" -// PODIO -#include -#include "podio/CollectionBase.h" -#include "podio/CollectionIDTable.h" -#include "podio/Frame.h" -#include "podio/ROOTFrameReader.h" -// Forward declarations -#include "k4FWCore/DataWrapper.h" -class DataWrapperBase; -class PodioOutput; -template class MetaDataHandle; +#include "k4FWCore/k4DataSvc.h" -/** @class PodioEvtSvc EvtDataSvc.h - * - * An EvtDataSvc for PODIO classes - * - * @author B. Hegner - */ -class PodioDataSvc : public DataSvc { - template friend class MetaDataHandle; - friend class PodioOutput; +using PodioDataSvc = k4DataSvc; -public: - typedef std::vector> CollRegistry; - - StatusCode initialize() final; - StatusCode reinitialize() final; - StatusCode finalize() final; - StatusCode clearStore() final; - StatusCode i_setRoot(std::string root_path, IOpaqueAddress* pRootAddr) final; - StatusCode i_setRoot(std::string root_path, DataObject* pRootObj) final; - - /// Standard Constructor - PodioDataSvc(const std::string& name, ISvcLocator* svc); - - /// Standard Destructor - virtual ~PodioDataSvc(); - - // Use DataSvc functionality except where we override - using DataSvc::registerObject; - /// Overriding standard behaviour of evt service - /// Register object with the data store. - virtual StatusCode registerObject(std::string_view parentPath, std::string_view fullPath, - DataObject* pObject) override final; - - const std::string_view getCollectionType(const std::string& collName); - - template StatusCode readCollection(const std::string& collName) { - DataObject* objectPtr = nullptr; - if (DataSvc::findObject("/Event", "/" + collName, objectPtr)) { - debug() << "Collection " << collName << " already read, not reading it again" << endmsg; - return StatusCode::SUCCESS; - } - const T* collection(nullptr); - collection = static_cast(m_eventframe.get(collName)); - if (collection == nullptr) { - error() << "Collection " << collName << " does not exist." << endmsg; - } - auto wrapper = new DataWrapper; - wrapper->setData(collection); - m_podio_datawrappers.push_back(wrapper); - return DataSvc::registerObject("/Event", "/" + collName, wrapper); - } - - const podio::Frame& getEventFrame() const { return m_eventframe; } - - /// Resets caches of reader and event store, increases event counter - void endOfRead(); - - /// TODO: Make this private again after conversions have been properly solved - podio::Frame& getMetaDataFrame() { return m_metadataframe; } - - bool hasCollection(const std::string& name) const { return m_eventframe.get(name); } - -private: - /// PODIO reader for ROOT files - podio::ROOTFrameReader m_reader; - /// PODIO Frame, used to initialise collections - podio::Frame m_eventframe; - /// PODIO Frame, used to store metadata - podio::Frame m_metadataframe; - /// Counter of the event number - int m_eventNum{0}; - /// Number of events in the file / to process - int m_numAvailableEvents{-1}; - int m_requestedEventMax{-1}; - /// Whether reading from file at all - bool m_reading_from_file{false}; - - SmartIF m_cnvSvc; - - // Registry of data wrappers; needed for memory management - std::vector m_podio_datawrappers; - -protected: - /// ROOT file name the input is read from. Set by option filename - std::vector m_filenames; - std::string m_filename; - /// Jump to nth events at the beginning. Set by option FirstEventEntry - /// This option is helpful when we want to debug an event in the middle of a file - unsigned m_1stEvtEntry{0}; - bool m_bounds_check_needed{true}; -}; -#endif // CORE_PODIODATASVC_H +#endif diff --git a/k4FWCore/include/k4FWCore/k4DataSvc.h b/k4FWCore/include/k4FWCore/k4DataSvc.h new file mode 100644 index 00000000..1980e874 --- /dev/null +++ b/k4FWCore/include/k4FWCore/k4DataSvc.h @@ -0,0 +1,120 @@ +/* + * Copyright (c) 2014-2023 Key4hep-Project. + * + * This file is part of Key4hep. + * See https://key4hep.github.io/key4hep-doc/ for further info. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef K4FWCORE_K4DATASVC_H +#define K4FWCORE_K4DATASVC_H + +#include "k4FWCore/DataWrapper.h" + +// PODIO +#include "podio/CollectionBase.h" +#include "podio/CollectionIDTable.h" +#include "podio/Frame.h" +#include "podio/ROOTFrameReader.h" + +// Gaudi +#include "GaudiKernel/DataSvc.h" +#include "GaudiKernel/IConversionSvc.h" + +#include + +class k4DataSvc : public DataSvc { + template friend class MetaDataHandle; + friend class PodioOutput; + +public: + /// Standard Constructor + k4DataSvc(const std::string& name, ISvcLocator* svc); + + StatusCode initialize() final; + StatusCode reinitialize() final; + StatusCode finalize() final; + StatusCode clearStore() final; + StatusCode i_setRoot(std::string root_path, IOpaqueAddress* pRootAddr) final; + StatusCode i_setRoot(std::string root_path, DataObject* pRootObj) final; + + /// Standard Destructor + virtual ~k4DataSvc() = default; + + // Use DataSvc functionality except where we override + using DataSvc::registerObject; + /// Overriding standard behaviour of evt service + /// Register object with the data store. + virtual StatusCode registerObject(std::string_view parentPath, std::string_view fullPath, + DataObject* pObject) override final; + + const std::string_view getCollectionType(const std::string& collName); + + template StatusCode readCollection(const std::string& collName) { + DataObject* objectPtr = nullptr; + if (DataSvc::findObject("/Event", "/" + collName, objectPtr)) { + debug() << "Collection " << collName << " already read, not reading it again" << endmsg; + return StatusCode::SUCCESS; + } + const T* collection(nullptr); + collection = static_cast(m_eventframe.get(collName)); + if (collection == nullptr) { + error() << "Collection " << collName << " does not exist." << endmsg; + } + auto wrapper = new DataWrapper; + wrapper->setData(collection); + m_podio_datawrappers.push_back(wrapper); + return DataSvc::registerObject("/Event", "/" + collName, wrapper); + } + + const podio::Frame& getEventFrame() const { return m_eventframe; } + + /// Resets caches of reader and event store, increases event counter + void endOfRead(); + + /// TODO: Make this private again after conversions have been properly solved + podio::Frame& getMetaDataFrame() { return m_metadataframe; } + + bool hasCollection(const std::string& name) const { return m_eventframe.get(name); } + +protected: + /// PODIO reader for ROOT files + podio::ROOTFrameReader m_reader; + /// PODIO Frame, used to initialise collections + podio::Frame m_eventframe; + /// PODIO Frame, used to store metadata + podio::Frame m_metadataframe; + /// Counter of the event number + int m_eventNum{0}; + /// Number of events in the file / to process + int m_numAvailableEvents{-1}; + int m_requestedEventMax{-1}; + /// Whether reading from file at all + bool m_reading_from_file{false}; + + SmartIF m_cnvSvc; + + // Registry of data wrappers; needed for memory management + std::vector m_podio_datawrappers; + + /// ROOT file name the input is read from. Set by option filename + std::vector m_filenames; + std::string m_filename; + /// Jump to nth events at the beginning. Set by option FirstEventEntry + /// This option is helpful when we want to debug an event in the middle of a file + unsigned m_1stEvtEntry{0}; + bool m_bounds_check_needed{true}; +}; + +#endif diff --git a/k4FWCore/src/PodioDataSvc.cpp b/k4FWCore/src/k4DataSvc.cpp similarity index 80% rename from k4FWCore/src/PodioDataSvc.cpp rename to k4FWCore/src/k4DataSvc.cpp index c93f7f04..0fa6af40 100644 --- a/k4FWCore/src/PodioDataSvc.cpp +++ b/k4FWCore/src/k4DataSvc.cpp @@ -16,20 +16,29 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -#include "k4FWCore/PodioDataSvc.h" -#include -#include "GaudiKernel/IConversionSvc.h" -#include "GaudiKernel/IEventProcessor.h" -#include "GaudiKernel/IProperty.h" -#include "GaudiKernel/ISvcLocator.h" + +#include "k4FWCore/k4DataSvc.h" #include "k4FWCore/DataWrapper.h" -#include "podio/CollectionBase.h" +#include +#include +#include +#include +#include + +// Instantiation of a static factory class used by clients to create +// instances of this service +DECLARE_COMPONENT(k4DataSvc) -#include "TTree.h" +/// Standard Constructor +k4DataSvc::k4DataSvc(const std::string& name, ISvcLocator* svc) : DataSvc(name, svc) { + declareProperty("inputs", m_filenames = {}, "Names of the files to read"); + declareProperty("input", m_filename = "", "Name of the file to read"); + declareProperty("FirstEventEntry", m_1stEvtEntry = 0, "First event to read"); +} /// Service initialisation -StatusCode PodioDataSvc::initialize() { +StatusCode k4DataSvc::initialize() { // Nothing to do: just call base class initialisation StatusCode status = DataSvc::initialize(); ISvcLocator* svc_loc = serviceLocator(); @@ -80,19 +89,21 @@ StatusCode PodioDataSvc::initialize() { return status; } + /// Service reinitialisation -StatusCode PodioDataSvc::reinitialize() { +StatusCode k4DataSvc::reinitialize() { // Do nothing for this service return StatusCode::SUCCESS; } + /// Service finalization -StatusCode PodioDataSvc::finalize() { +StatusCode k4DataSvc::finalize() { m_cnvSvc = 0; // release DataSvc::finalize().ignore(); return StatusCode::SUCCESS; } -StatusCode PodioDataSvc::clearStore() { +StatusCode k4DataSvc::clearStore() { // as the frame takes care of the ownership of the podio::Collections, // make sure the DataWrappers don't cause a double delete for (auto wrapper : m_podio_datawrappers) { @@ -104,7 +115,7 @@ StatusCode PodioDataSvc::clearStore() { return StatusCode::SUCCESS; } -StatusCode PodioDataSvc::i_setRoot(std::string root_path, IOpaqueAddress* pRootAddr) { +StatusCode k4DataSvc::i_setRoot(std::string root_path, IOpaqueAddress* pRootAddr) { // create a new frame if (m_reading_from_file) { m_eventframe = podio::Frame(m_reader.readEntry("events", m_eventNum + m_1stEvtEntry)); @@ -114,7 +125,7 @@ StatusCode PodioDataSvc::i_setRoot(std::string root_path, IOpaqueAddress* pRootA return DataSvc::i_setRoot(root_path, pRootAddr); } -StatusCode PodioDataSvc::i_setRoot(std::string root_path, DataObject* pRootObj) { +StatusCode k4DataSvc::i_setRoot(std::string root_path, DataObject* pRootObj) { // create a new frame if (m_reading_from_file) { m_eventframe = podio::Frame(m_reader.readEntry("events", m_eventNum + m_1stEvtEntry)); @@ -124,7 +135,7 @@ StatusCode PodioDataSvc::i_setRoot(std::string root_path, DataObject* pRootObj) return DataSvc::i_setRoot(root_path, pRootObj); } -void PodioDataSvc::endOfRead() { +void k4DataSvc::endOfRead() { m_eventNum++; if (!m_bounds_check_needed) { @@ -143,13 +154,7 @@ void PodioDataSvc::endOfRead() { // todo: figure out sthg to do with sc (added to silence -Wunused-result) } -/// Standard Constructor -PodioDataSvc::PodioDataSvc(const std::string& name, ISvcLocator* svc) : DataSvc(name, svc) {} - -/// Standard Destructor -PodioDataSvc::~PodioDataSvc() {} - -const std::string_view PodioDataSvc::getCollectionType(const std::string& collName) { +const std::string_view k4DataSvc::getCollectionType(const std::string& collName) { const auto coll = m_eventframe.get(collName); if (coll == nullptr) { error() << "Collection " << collName << " does not exist." << endmsg; @@ -158,7 +163,7 @@ const std::string_view PodioDataSvc::getCollectionType(const std::string& collNa return coll->getTypeName(); } -StatusCode PodioDataSvc::registerObject(std::string_view parentPath, std::string_view fullPath, DataObject* pObject) { +StatusCode k4DataSvc::registerObject(std::string_view parentPath, std::string_view fullPath, DataObject* pObject) { DataWrapperBase* wrapper = dynamic_cast(pObject); if (wrapper != nullptr) { podio::CollectionBase* coll = wrapper->collectionBase();