DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
CTBMisc.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
13
14
15namespace dunedaq {
16 namespace appmodel {
17 const std::string& CTBMisc::s_class_name(dunedaq::conffwk::DalFactory::instance().get_known_class_name_ref("CTBMisc"));
18
19 // the factory initializer
20
22 {
24 {
25 dunedaq::conffwk::DalFactory::instance().register_dal_class<CTBMisc>("CTBMisc");
26 }
28
29
30 // the constructor
31
35 m_pulser (nullptr),
36 m_timing (nullptr)
37
38 {
39 ;
40 }
41
42
43 void CTBMisc::print(unsigned int indent, bool print_header, std::ostream& s) const
44 {
45 check_init();
46
47 try {
48 const std::string str(indent+2, ' ');
49
50 if (print_header)
51 p_hdr(s, indent, s_class_name, "dunedaq::appmodel");
52
53
54 // print direct super-classes
55
57
58
59 // print direct attributes
60
62
63
64 // print direct relationships
65
68 }
69 catch (dunedaq::conffwk::Exception & ex) {
71 }
72 }
73
74
75 void CTBMisc::init(bool init_children)
76 {
77 ResourceSetAND::init(init_children);
78
79 TLOG_DEBUG(5) << "read object " << this << " (class " << s_class_name << ')';
80
81 try {
85 }
86 catch (dunedaq::conffwk::Exception & ex) {
87 throw_init_ex(ex);
88 }
89 }
90
92 {
93 }
94
95 std::vector<const dunedaq::conffwk::DalObject *> CTBMisc::get(const std::string& name, bool upcast_unregistered) const
96 {
97 std::vector<const dunedaq::conffwk::DalObject *> vec;
98
99 if (!get(name, vec, upcast_unregistered, true))
100 throw_get_ex(name, s_class_name, this);
101
102 return vec;
103 }
104
105 bool CTBMisc::get(const std::string& name, std::vector<const dunedaq::conffwk::DalObject *>& vec, bool upcast_unregistered, bool first_call) const
106 {
107 if (first_call)
108 {
109 std::lock_guard scoped_lock(m_mutex);
110
111 check();
112 check_init();
113
114 if (get_rel_objects(name, upcast_unregistered, vec))
115 return true;
116 }
117
118 if (ResourceSetAND::get(name, vec, upcast_unregistered, false)) return true;
119
120 if (first_call)
121 return get_algo_objects(name, vec);
122
123 return false;
124 }
125
127 {
128 _set_object(s_pulser, value);
129 }
130
132 {
133 _set_object(s_timing, value);
134 }
135
136 }
137}
const dunedaq::appmodel::CTBTiming * m_timing
Definition CTBMisc.hpp:94
static const std::string s_pulser
Definition CTBMisc.hpp:139
static const std::string s_timing
Definition CTBMisc.hpp:140
virtual void init(bool init_children)
Definition CTBMisc.cpp:75
static const std::string & s_class_name
Definition CTBMisc.hpp:58
const dunedaq::appmodel::CTBPulser * m_pulser
Definition CTBMisc.hpp:93
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...
Definition CTBMisc.cpp:95
virtual ~CTBMisc() noexcept
Definition CTBMisc.cpp:91
void set_timing(const dunedaq::appmodel::CTBTiming *value)
Set "timing" relationship value.
Definition CTBMisc.cpp:131
virtual void print(unsigned int offset, bool print_header, std::ostream &s) const
Print details of the CTBMisc object.
Definition CTBMisc.cpp:43
CTBMisc(conffwk::DalRegistry &db, const conffwk::ConfigObject &obj) noexcept
Definition CTBMisc.cpp:32
static const std::string s_ch_status
Definition CTBMisc.hpp:101
void set_pulser(const dunedaq::appmodel::CTBPulser *value)
Set "pulser" relationship value.
Definition CTBMisc.cpp:126
void get(const std::string &name, T &value)
Get value of object's attribute or relationship.
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
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 ResourceSetAND 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_sv_attr(std::ostream &s, const std::string &str, const std::string &name, const T &val) noexcept
print single-value attribute
Including Qt Headers.