DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
TimingHardwareInterface.cpp
Go to the documentation of this file.
4#include "conffwk/Errors.hpp"
6
7#include "logging/Logging.hpp"
8
9namespace dunedaq {
10 namespace timinglibs {
11 namespace dal {
12 const std::string& TimingHardwareInterface::s_class_name(dunedaq::conffwk::DalFactory::instance().get_known_class_name_ref("TimingHardwareInterface"));
13
14 // the factory initializer
15
17 {
19 {
20 dunedaq::conffwk::DalFactory::instance().register_dal_class<TimingHardwareInterface>("TimingHardwareInterface");
21 }
23
24
25 // the constructor
26
32
33
34 void TimingHardwareInterface::print(unsigned int indent, bool print_header, std::ostream& s) const
35 {
36 check_init();
37
38 try {
39
40 if (print_header)
41 p_hdr(s, indent, s_class_name, "dunedaq::timinglibs::dal");
42 }
43 catch (dunedaq::conffwk::Exception & ex) {
45 }
46 }
47
48
49 void TimingHardwareInterface::init(bool /* init_children */)
50 {
51 p_was_read = true;
53 TLOG_DEBUG(5) << "read object " << this << " (class " << s_class_name << ')';
54 }
55
59
60 std::vector<const dunedaq::conffwk::DalObject *> TimingHardwareInterface::get(const std::string& name, bool upcast_unregistered) const
61 {
62 std::vector<const dunedaq::conffwk::DalObject *> vec;
63
64 if (!get(name, vec, upcast_unregistered, true))
65 throw_get_ex(name, s_class_name, this);
66
67 return vec;
68 }
69
70 bool TimingHardwareInterface::get(const std::string& name, std::vector<const dunedaq::conffwk::DalObject *>& vec, bool upcast_unregistered, bool first_call) const
71 {
72 if (first_call)
73 {
74 std::lock_guard scoped_lock(m_mutex);
75
76 check();
77 check_init();
78
79 if (get_rel_objects(name, upcast_unregistered, vec))
80 return true;
81 }
82
83 if (first_call)
84 return get_algo_objects(name, vec);
85
86 return false;
87 }
88
89 }
90 }
91}
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 increment_read() noexcept
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.
bool p_was_read
is true, if the object was read
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
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...
TimingHardwareInterface()
TimingHardwareInterface Constructor.
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...
virtual void print(unsigned int offset, bool print_header, std::ostream &s) const
Print details of the TimingHardwareInterface object.
#define TLOG_DEBUG(lvl,...)
Definition Logging.hpp:112
static struct dunedaq::timinglibs::dal::__EndpointLocation_Registrator registrator
Including Qt Headers.