gdata
Loading...
Searching...
No Matches
gFrameDataCollection.h
Go to the documentation of this file.
1#pragma once
2
30#include "gFrameHeader.h"
31#include "gIntegralPayload.h"
32#include "gdataConventions.h"
33#include <vector>
34
49{
50public:
64 GFrameDataCollection(GFrameHeader* header, std::shared_ptr<GLogger> logger)
65 : log(logger), gevent_header(header) {
66 log->debug(CONSTRUCTOR, "GFrameDataCollection");
67 integralPayloads = new std::vector<GIntegralPayload*>();
68 }
69
85 log->debug(DESTRUCTOR, "GFrameDataCollection");
86 delete gevent_header;
87 for (auto* payload : *integralPayloads) { delete payload; }
88 delete integralPayloads;
89 }
90
91public:
115 void addIntegralPayload(std::vector<int> payload) const {
116 // Decode the fixed packed layout only when the payload size matches the contract.
117 if (payload.size() == 5) {
118 int crate = payload[0];
119 int slot = payload[1];
120 int channel = payload[2];
121 int charge = payload[3];
122 int time = payload[4];
123
124 // Create and store one owned payload object for this frame.
125 auto gpayload = new GIntegralPayload(crate, slot, channel, charge, time, log);
126 integralPayloads->push_back(gpayload);
127 log->debug(NORMAL, " adding integral payload for crate ", crate, " slot ", slot, " channel ", channel,
128 " charge ", charge, " time ", time);
129 }
130 else {
131 // Reject malformed packed payloads and keep the collection unchanged.
132 log->error(ERR_WRONGPAYLOAD, "payload size is not 5 but ", payload.size());
133 }
134 }
135
146 void addEvent(int evn);
147
159 [[nodiscard]] bool shouldWriteFrame() const;
160
170 [[nodiscard]] inline const GFrameHeader* getHeader() const { return gevent_header; }
171
183 [[nodiscard]] inline const std::vector<GIntegralPayload*>* getIntegralPayload() const { return integralPayloads; }
184
193 [[nodiscard]] inline long int getFrameID() const { return gevent_header->getFrameID(); }
194
195private:
196 std::shared_ptr<GLogger> log;
197 GFrameHeader* gevent_header = nullptr;
198 std::vector<GIntegralPayload*>* integralPayloads;
199};
Owns one frame header and the list of payloads accumulated for that frame.
const GFrameHeader * getHeader() const
Returns the owned frame header.
bool shouldWriteFrame() const
Placeholder decision hook indicating whether this frame should be emitted.
void addIntegralPayload(std::vector< int > payload) const
Add one integral payload to this frame.
long int getFrameID() const
Convenience getter for the frame ID.
const std::vector< GIntegralPayload * > * getIntegralPayload() const
Returns the stored payload pointers.
GFrameDataCollection(GFrameHeader *header, std::shared_ptr< GLogger > logger)
Construct a frame data collection.
void addEvent(int evn)
Placeholder for adding event-level information into the frame.
Stores minimal metadata for one frame-style time window.
long int getFrameID() const
Returns the frame identifier.
void debug(debug_type type, Args &&... args) const
void error(int exit_code, Args &&... args) const
Defines the GFrameHeader class, a minimal header describing a frame.
Defines GIntegralPayload, one integrated electronics payload sample.
Shared constants, schema keys, and error codes for the GData module.
constexpr int ERR_WRONGPAYLOAD
Packed payload vector has an unexpected size or layout.
CONSTRUCTOR
NORMAL
DESTRUCTOR
Stores one integrated readout payload sample.