DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
HDF5FileLayoutParams.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
12
13
14namespace dunedaq {
15 namespace appmodel {
16 const std::string& HDF5FileLayoutParams::s_class_name(dunedaq::conffwk::DalFactory::instance().get_known_class_name_ref("HDF5FileLayoutParams"));
17
18 // the factory initializer
19
21 {
23 {
24 dunedaq::conffwk::DalFactory::instance().register_dal_class<HDF5FileLayoutParams>("HDF5FileLayoutParams");
25 }
27
28
29 // the constructor
30
36
37
38 void HDF5FileLayoutParams::print(unsigned int indent, bool print_header, std::ostream& s) const
39 {
40 check_init();
41
42 try {
43 const std::string str(indent+2, ' ');
44
45 if (print_header)
46 p_hdr(s, indent, s_class_name, "dunedaq::appmodel");
47
48
49 // print direct attributes
50
57
58
59 // print direct relationships
60
62 }
63 catch (dunedaq::conffwk::Exception & ex) {
65 }
66 }
67
68
88
92
93 std::vector<const dunedaq::conffwk::DalObject *> HDF5FileLayoutParams::get(const std::string& name, bool upcast_unregistered) const
94 {
95 std::vector<const dunedaq::conffwk::DalObject *> vec;
96
97 if (!get(name, vec, upcast_unregistered, true))
98 throw_get_ex(name, s_class_name, this);
99
100 return vec;
101 }
102
103 bool HDF5FileLayoutParams::get(const std::string& name, std::vector<const dunedaq::conffwk::DalObject *>& vec, bool upcast_unregistered, bool first_call) const
104 {
105 if (first_call)
106 {
107 std::lock_guard scoped_lock(m_mutex);
108
109 check();
110 check_init();
111
112 if (get_rel_objects(name, upcast_unregistered, vec))
113 return true;
114 }
115
116 if (first_call)
117 return get_algo_objects(name, vec);
118
119 return false;
120 }
121
122 void HDF5FileLayoutParams::set_path_params_list(const std::vector<const dunedaq::appmodel::HDF5PathParams*>& value)
123 {
125 }
126
127 }
128}
void set_path_params_list(const std::vector< const dunedaq::appmodel::HDF5PathParams * > &value)
Set "path_params_list" relationship value.
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...
static const std::string s_record_header_dataset_name
std::vector< const dunedaq::appmodel::HDF5PathParams * > m_path_params_list
virtual void init(bool init_children)
static const std::string s_digits_for_sequence_number
HDF5FileLayoutParams(conffwk::DalRegistry &db, const conffwk::ConfigObject &obj) noexcept
virtual void print(unsigned int offset, bool print_header, std::ostream &s) const
Print details of the HDF5FileLayoutParams object.
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
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
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.
DalRegistry & p_registry
Configuration 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
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).
#define TLOG_DEBUG(lvl,...)
Definition Logging.hpp:112
static struct dunedaq::appmodel::__AVXAbsRunSumProcessor_Registrator registrator
void p_mv_rel(std::ostream &s, const std::string &str, const std::string &name, const T &objs) noexcept
print weak multi-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.