EDM4eic
EIC data model
Loading...
Searching...
No Matches
Measurement2DCollectionData.h
Go to the documentation of this file.
1// AUTOMATICALLY GENERATED FILE - DO NOT EDIT
2
3#ifndef EDM4EIC_Measurement2D_CollectionData_H
4#define EDM4EIC_Measurement2D_CollectionData_H
5
6// datamodel specific includes
10#include "edm4eic/TrackerHit.h"
11
12// schema evolution specific includes
13
14// podio specific includes
15#include "podio/CollectionBuffers.h"
16#include "podio/ICollectionProvider.h"
17
18#include <deque>
19#include <memory>
20
21namespace edm4eic {
22
23
24using Measurement2DObjPointerContainer = std::deque<Measurement2DObj*>;
25using Measurement2DDataContainer = std::vector<Measurement2DData>;
26
27
28/**
29 * Class encapsulating everything related to storage of data that is needed by a
30 * collection.
31 */
33public:
34 /**
35 * The Objs of this collection
36 */
38
39 /**
40 * Default constructor setting up the necessary buffers
41 */
43
44 /**
45 * Constructor from existing I/O buffers
46 */
47 Measurement2DCollectionData(podio::CollectionReadBuffers buffers, bool isSubsetColl);
48
49 /**
50 * Non copy-able, move-only class
51 */
56
57 /**
58 * Destructor
59 */
61
62 void clear(bool isSubsetColl);
63
64 podio::CollectionWriteBuffers getCollectionBuffers(bool isSubsetColl);
65
66 void prepareForWrite(bool isSubsetColl);
67
68 void prepareAfterRead(uint32_t collectionID);
69
71
73
74 bool setReferences(const podio::ICollectionProvider* collectionProvider, bool isSubsetColl);
75
76private:
77 // members to handle 1-to-N-relations
78 podio::UVecPtr<edm4eic::TrackerHit> m_rel_hits{std::make_unique<std::vector<edm4eic::TrackerHit>>()}; ///< Relation buffer for read / write
79 std::vector<podio::UVecPtr<edm4eic::TrackerHit>> m_rel_hits_tmp{}; ///< Relation buffer for internal book-keeping
80
81 // members to handle vector members
82 podio::UVecPtr<float> m_vec_weights{nullptr}; /// combined vector of all objects in collection
83 std::vector<podio::UVecPtr<float>> m_vecs_weights{}; /// pointers to individual member vectors
84
85 // I/O related buffers
86 podio::CollRefCollection m_refCollections{};
87 podio::VectorMembersInfo m_vecmem_info{};
88 std::unique_ptr<Measurement2DDataContainer> m_data{nullptr};
89};
90
91
92} // namespace edm4eic
93
94
95#endif
Measurement2DCollectionData & operator=(const Measurement2DCollectionData &)=delete
void makeSubsetCollection()
Definition Measurement2DCollectionData.cc:195
Measurement2DCollectionData(Measurement2DCollectionData &&other)=default
void createRelations(Measurement2DObj *obj)
Definition Measurement2DCollectionData.cc:155
Measurement2DObjPointerContainer entries
Definition Measurement2DCollectionData.h:37
Measurement2DCollectionData & operator=(Measurement2DCollectionData &&other)=default
void prepareAfterRead(uint32_t collectionID)
Definition Measurement2DCollectionData.cc:139
podio::CollectionWriteBuffers getCollectionBuffers(bool isSubsetColl)
Definition Measurement2DCollectionData.cc:85
bool setReferences(const podio::ICollectionProvider *collectionProvider, bool isSubsetColl)
Definition Measurement2DCollectionData.cc:162
void prepareForWrite(bool isSubsetColl)
Definition Measurement2DCollectionData.cc:99
Measurement2DCollectionData()
Definition Measurement2DCollectionData.cc:14
void clear(bool isSubsetColl)
Definition Measurement2DCollectionData.cc:52
Measurement2DCollectionData(const Measurement2DCollectionData &)=delete
Definition Measurement2DObj.h:20
Definition CalorimeterHit.cc:17
std::deque< Measurement2DObj * > Measurement2DObjPointerContainer
Definition Measurement2DCollectionData.h:24
std::vector< Measurement2DData > Measurement2DDataContainer
Definition Measurement2DCollectionData.h:25