EDM4eic
EIC data model
Loading...
Searching...
No Matches
TrackCollectionData.h
Go to the documentation of this file.
1// AUTOMATICALLY GENERATED FILE - DO NOT EDIT
2
3#ifndef EDM4EIC_Track_CollectionData_H
4#define EDM4EIC_Track_CollectionData_H
5
6// datamodel specific includes
7#include "edm4eic/TrackData.h"
8#include "edm4eic/TrackObj.h"
9#include "edm4eic/Track.h"
11#include "edm4eic/Trajectory.h"
12
13// schema evolution specific includes
14
15// podio specific includes
16#include "podio/CollectionBuffers.h"
17#include "podio/ICollectionProvider.h"
18
19#include <deque>
20#include <memory>
21
22namespace edm4eic {
23
24
25using TrackObjPointerContainer = std::deque<TrackObj*>;
26using TrackDataContainer = std::vector<TrackData>;
27
28
29/**
30 * Class encapsulating everything related to storage of data that is needed by a
31 * collection.
32 */
34public:
35 /**
36 * The Objs of this collection
37 */
39
40 /**
41 * Default constructor setting up the necessary buffers
42 */
44
45 /**
46 * Constructor from existing I/O buffers
47 */
48 TrackCollectionData(podio::CollectionReadBuffers buffers, bool isSubsetColl);
49
50 /**
51 * Non copy-able, move-only class
52 */
57
58 /**
59 * Destructor
60 */
62
63 void clear(bool isSubsetColl);
64
65 podio::CollectionWriteBuffers getCollectionBuffers(bool isSubsetColl);
66
67 void prepareForWrite(bool isSubsetColl);
68
69 void prepareAfterRead(uint32_t collectionID);
70
72
73 void createRelations(TrackObj* obj);
74
75 bool setReferences(const podio::ICollectionProvider* collectionProvider, bool isSubsetColl);
76
77private:
78 // members to handle 1-to-N-relations
79 podio::UVecPtr<edm4eic::Measurement2D> m_rel_measurements{std::make_unique<std::vector<edm4eic::Measurement2D>>()}; ///< Relation buffer for read / write
80 std::vector<podio::UVecPtr<edm4eic::Measurement2D>> m_rel_measurements_tmp{}; ///< Relation buffer for internal book-keeping
81 podio::UVecPtr<edm4eic::Track> m_rel_tracks{std::make_unique<std::vector<edm4eic::Track>>()}; ///< Relation buffer for read / write
82 std::vector<podio::UVecPtr<edm4eic::Track>> m_rel_tracks_tmp{}; ///< Relation buffer for internal book-keeping
83 podio::UVecPtr<edm4eic::Trajectory> m_rel_trajectory{std::make_unique<std::vector<edm4eic::Trajectory>>()}; ///< Relation buffer for read / write
84
85 // members to handle vector members
86
87 // I/O related buffers
88 podio::CollRefCollection m_refCollections{};
89 podio::VectorMembersInfo m_vecmem_info{};
90 std::unique_ptr<TrackDataContainer> m_data{nullptr};
91};
92
93
94} // namespace edm4eic
95
96
97#endif
TrackCollectionData(const TrackCollectionData &)=delete
bool setReferences(const podio::ICollectionProvider *collectionProvider, bool isSubsetColl)
Definition TrackCollectionData.cc:182
void prepareForWrite(bool isSubsetColl)
Definition TrackCollectionData.cc:109
TrackCollectionData & operator=(const TrackCollectionData &)=delete
TrackCollectionData & operator=(TrackCollectionData &&other)=default
void makeSubsetCollection()
Definition TrackCollectionData.cc:243
podio::CollectionWriteBuffers getCollectionBuffers(bool isSubsetColl)
Definition TrackCollectionData.cc:100
void clear(bool isSubsetColl)
Definition TrackCollectionData.cc:53
void prepareAfterRead(uint32_t collectionID)
Definition TrackCollectionData.cc:159
TrackCollectionData(TrackCollectionData &&other)=default
TrackObjPointerContainer entries
Definition TrackCollectionData.h:38
TrackCollectionData()
Definition TrackCollectionData.cc:14
void createRelations(TrackObj *obj)
Definition TrackCollectionData.cc:175
Definition TrackObj.h:24
Definition CalorimeterHit.cc:17
std::vector< TrackData > TrackDataContainer
Definition TrackCollectionData.h:26
std::deque< TrackObj * > TrackObjPointerContainer
Definition TrackCollectionData.h:25