8bool GstreamerCsvFactory::publishEventTrueInfoDataImpl(
const std::string& detectorName,
9 const std::vector<const GTrueInfoData*>& trueInfoData) {
10 if (!ofile_true_info.is_open()) {
16 if (!is_first_event_with_truedata) {
17 if (trueInfoData.size() > 0) {
18 ofile_true_info <<
"evn, timestamp, thread_id, detector, ";
19 auto first_hit = trueInfoData[0];
21 const auto& smap = first_hit->getStringVariablesMap();
22 const auto& dmap = first_hit->getDoubleVariablesMap();
24 size_t total = dmap.size();
27 log->
debug(NORMAL, SFUNCTION_NAME,
"Writing header for event ", event_number,
" with ", total,
30 for (
const auto& [name, value] : smap) { ofile_true_info << name <<
", "; }
32 for (
const auto& [name, value] : dmap) {
33 ofile_true_info << name;
34 if (++i < total) ofile_true_info <<
", ";
37 ofile_true_info <<
"\n";
39 is_first_event_with_truedata =
true;
44 if (is_first_event_with_truedata) {
45 for (
auto trueInfoHit : trueInfoData) {
46 const auto& smap = trueInfoHit->getStringVariablesMap();
47 const auto& dmap = trueInfoHit->getDoubleVariablesMap();
49 size_t total = dmap.size();
52 ofile_true_info << event_number <<
", " << timestamp <<
", " << thread_id <<
", " << detectorName <<
", ";
54 for (
const auto& [variableName, value] : smap) { ofile_true_info << value <<
", "; }
55 for (
const auto& [variableName, value] : dmap) {
56 ofile_true_info << value;
57 if (++i < total) ofile_true_info <<
", ";
58 else ofile_true_info <<
"\n";
std::shared_ptr< GLogger > log
void debug(debug_type type, Args &&... args) const
void error(int exit_code, Args &&... args) const
CSV streamer plugin declarations.
Shared constants and error codes for the gstreamer module.
#define ERR_CANTOPENOUTPUT
Output medium could not be opened successfully.