49 : log(logger), gevent_header(header) {
51 integralPayloads =
new std::vector<GIntegralPayload*>();
70 for (
auto* payload : *integralPayloads) {
delete payload; }
71 delete integralPayloads;
98 if (payload.size() == 5) {
99 int crate = payload[0];
100 int slot = payload[1];
101 int channel = payload[2];
102 int charge = payload[3];
103 int time = payload[4];
105 auto gpayload =
new GIntegralPayload(crate, slot, channel, charge, time, log);
106 integralPayloads->push_back(gpayload);
107 log->
debug(
NORMAL,
" adding integral payload for crate ", crate,
" slot ", slot,
" channel ", channel,
108 " charge ", charge,
" time ", time);
161 [[nodiscard]]
inline const std::vector<GIntegralPayload*>*
getIntegralPayload()
const {
return integralPayloads; }
174 std::shared_ptr<GLogger> log;
176 std::vector<GIntegralPayload*>* integralPayloads;
~GFrameDataCollection()
Destructor.
const GFrameHeader * getHeader() const
Get the owned frame header (read-only).
bool shouldWriteFrame() const
Placeholder decision hook: should this frame be emitted/written?
void addIntegralPayload(std::vector< int > payload) const
Add one integral payload to this frame.
long int getFrameID() const
Convenience getter for frame ID.
const std::vector< GIntegralPayload * > * getIntegralPayload() const
Get the stored payload pointers (read-only).
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.
void debug(debug_type type, Args &&... args) const
void error(int exit_code, Args &&... args) const
Defines GIntegralPayload, one integrated electronics payload sample.
Shared constants and error codes for the GData library.
constexpr int ERR_WRONGPAYLOAD
A payload vector has the wrong size/shape for the expected format.