DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
CTBoardConf.cpp
Go to the documentation of this file.
4#include "conffwk/Errors.hpp"
6
7#include "logging/Logging.hpp"
8
9 // include files for classes used in relationships and algorithms
10
11#include "confmodel/GeoId.hpp"
14#include "appmodel/CTBHLT.hpp"
15#include "appmodel/CTBLLT.hpp"
16#include "appmodel/CTBMisc.hpp"
20
21
22namespace dunedaq {
23 namespace appmodel {
24 const std::string& CTBoardConf::s_class_name(dunedaq::conffwk::DalFactory::instance().get_known_class_name_ref("CTBoardConf"));
25
26 // the factory initializer
27
29 {
31 {
32 dunedaq::conffwk::DalFactory::instance().register_dal_class<CTBoardConf>("CTBoardConf");
33 }
35
36
37 // the constructor
38
42 m_sockets (nullptr),
43 m_beam (nullptr),
44 m_CRT (nullptr),
45 m_pds (nullptr),
46 m_geo_id (nullptr),
47 m_misc (nullptr)
48
49 {
50 ;
51 }
52
53
54 void CTBoardConf::print(unsigned int indent, bool print_header, std::ostream& s) const
55 {
56 check_init();
57
58 try {
59 const std::string str(indent+2, ' ');
60
61 if (print_header)
62 p_hdr(s, indent, s_class_name, "dunedaq::appmodel");
63
64
65 // print direct super-classes
66
68
69
70 // print direct relationships
71
81 }
82 catch (dunedaq::conffwk::Exception & ex) {
84 }
85 }
86
87
88 void CTBoardConf::init(bool init_children)
89 {
90 ResourceSetDisableAND::init(init_children);
91
92 TLOG_DEBUG(5) << "read object " << this << " (class " << s_class_name << ')';
93
94 try {
104 }
105 catch (dunedaq::conffwk::Exception & ex) {
106 throw_init_ex(ex);
107 }
108 }
109
111 {
112 }
113
114 std::vector<const dunedaq::conffwk::DalObject *> CTBoardConf::get(const std::string& name, bool upcast_unregistered) const
115 {
116 std::vector<const dunedaq::conffwk::DalObject *> vec;
117
118 if (!get(name, vec, upcast_unregistered, true))
119 throw_get_ex(name, s_class_name, this);
120
121 return vec;
122 }
123
124 bool CTBoardConf::get(const std::string& name, std::vector<const dunedaq::conffwk::DalObject *>& vec, bool upcast_unregistered, bool first_call) const
125 {
126 if (first_call)
127 {
128 std::lock_guard scoped_lock(m_mutex);
129
130 check();
131 check_init();
132
133 if (get_rel_objects(name, upcast_unregistered, vec))
134 return true;
135 }
136
137 if (ResourceSetDisableAND::get(name, vec, upcast_unregistered, false)) return true;
138
139 if (first_call)
140 return get_algo_objects(name, vec);
141
142 return false;
143 }
144
149
151 {
152 _set_object(s_beam, value);
153 }
154
156 {
157 _set_object(s_CRT, value);
158 }
159
161 {
162 _set_object(s_pds, value);
163 }
164
166 {
167 _set_object(s_geo_id, value);
168 }
169
171 {
172 _set_object(s_misc, value);
173 }
174
175 void CTBoardConf::set_HLTs(const std::vector<const dunedaq::appmodel::CTBHLT*>& value)
176 {
177 _set_objects(s_HLTs, value);
178 }
179
180 void CTBoardConf::set_CRT_LLTs(const std::vector<const dunedaq::appmodel::CTBCountLLT*>& value)
181 {
182 _set_objects(s_CRT_LLTs, value);
183 }
184
185 void CTBoardConf::set_beam_LLTs(const std::vector<const dunedaq::appmodel::CTBLLT*>& value)
186 {
188 }
189
190 }
191}
std::vector< const dunedaq::appmodel::CTBCountLLT * > m_CRT_LLTs
static const std::string s_misc
virtual void print(unsigned int offset, bool print_header, std::ostream &s) const
Print details of the CTBoardConf object.
const dunedaq::appmodel::CTBSubsystem * m_beam
const dunedaq::appmodel::CTBCRTSubsystem * m_CRT
static const std::string s_sockets
static const std::string s_pds
virtual ~CTBoardConf() noexcept
static const std::string s_HLTs
void set_CRT(const dunedaq::appmodel::CTBCRTSubsystem *value)
Set "CRT" relationship value.
void set_HLTs(const std::vector< const dunedaq::appmodel::CTBHLT * > &value)
Set "HLTs" relationship value.
const dunedaq::appmodel::CTBPDSSubsystem * m_pds
void set_pds(const dunedaq::appmodel::CTBPDSSubsystem *value)
Set "pds" relationship value.
void set_CRT_LLTs(const std::vector< const dunedaq::appmodel::CTBCountLLT * > &value)
Set "CRT_LLTs" relationship value.
static const std::string s_beam_LLTs
const dunedaq::appmodel::CTBMisc * m_misc
std::vector< const dunedaq::appmodel::CTBLLT * > m_beam_LLTs
void set_beam(const dunedaq::appmodel::CTBSubsystem *value)
Set "beam" relationship value.
static const std::string s_CRT_LLTs
static const std::string s_CRT
void set_beam_LLTs(const std::vector< const dunedaq::appmodel::CTBLLT * > &value)
Set "beam_LLTs" relationship value.
const dunedaq::confmodel::GeoId * m_geo_id
static const std::string s_geo_id
virtual std::vector< const dunedaq::conffwk::DalObject * > get(const std::string &name, bool upcast_unregistered=true) const
Get values of relationships and results of some algorithms as a vector of dunedaq::conffwk::DalObject...
void set_misc(const dunedaq::appmodel::CTBMisc *value)
Set "misc" relationship value.
const dunedaq::appmodel::CTBSockets * m_sockets
std::vector< const dunedaq::appmodel::CTBHLT * > m_HLTs
void set_geo_id(const dunedaq::confmodel::GeoId *value)
Set "geo_id" relationship value.
static const std::string & s_class_name
void set_sockets(const dunedaq::appmodel::CTBSockets *value)
Set "sockets" relationship value.
CTBoardConf(conffwk::DalRegistry &db, const conffwk::ConfigObject &obj) noexcept
virtual void init(bool init_children)
static const std::string s_beam
The base class for any generated DAL object.
Definition DalObject.hpp:45
void p_hdr(std::ostream &s, unsigned int indent, const std::string &cl, const char *nm=nullptr) const
print object headers
Definition DalObject.cpp:65
void throw_init_ex(dunedaq::conffwk::Exception &ex)
throw object initialisation exception (i.e.
Definition DalObject.cpp:74
static void p_error(std::ostream &s, dunedaq::conffwk::Exception &ex)
print error text
Definition DalObject.cpp:59
bool get_rel_objects(const std::string &name, bool upcast_unregistered, std::vector< const DalObject * > &objs) const
Read relationship values as DAL objects using DAL factory.
Definition DalObject.cpp:8
static void throw_get_ex(const std::string &what, const std::string &class_name, const DalObject *obj)
throw exception in generated get method (i.e.
Definition DalObject.cpp:82
void _set_objects(const std::string &name, const std::vector< const T * > &value)
Helper method for generated set multi-value relationship methods.
std::mutex m_mutex
Used to protect changes of DAL object.
void _set_object(const std::string &name, const T *value)
Helper method for generated set single-value relationship methods.
DalRegistry & p_registry
Configuration object.
bool get_algo_objects(const std::string &name, std::vector< const DalObject * > &objs) const
Run algorithm and return result as DAL objects using DAL factory.
Definition DalObject.cpp:25
ConfigObject p_obj
Config object used by given template object.
void check_init() const
Check and initialize object if necessary.
DalRegistry: A registry of DalObjects It provides a single interface to create, cache and manage DalO...
const T * _ref(ConfigObject &obj, const std::string &name, bool read_children)
Get signle value of object's relation and instantiate result with it (multi-thread safe).
virtual void print(unsigned int offset, bool print_header, std::ostream &s) const
Print details of the ResourceSetDisableAND object.
#define TLOG_DEBUG(lvl,...)
Definition Logging.hpp:112
static struct dunedaq::appmodel::__AVXAbsRunSumProcessor_Registrator registrator
void p_sv_rel(std::ostream &s, const std::string &str, const std::string &name, const DalObject *obj)
print weak single-value relationship
void p_mv_rel(std::ostream &s, const std::string &str, const std::string &name, const T &objs) noexcept
print weak multi-value relationship
The DUNE-DAQ namespace.
Definition DataStore.hpp:57