DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
TimingHardwareManagerBase.hpp
Go to the documentation of this file.
1// *** this file is generated by oksdalgen, do not modify it ***
2
3#ifndef _TimingHardwareManagerBase_0_dunedaq__timinglibs__dal_0_timinglibs_dal_H_
4#define _TimingHardwareManagerBase_0_dunedaq__timinglibs__dal_0_timinglibs_dal_H_
5
6#include <stdint.h> // to define 64 bits types
7#include <iostream>
8#include <sstream>
9#include <string>
10#include <map>
11#include <vector>
12
14#include "conffwk/DalObject.hpp"
15
16 // include files for classes used in inheritance hierarchy
17
20
21 // forward declaration for classes used in relationships and algorithms
22
23namespace dunedaq {
24 namespace timinglibs {
25 namespace dal {
26 class TimingHardwareManagerConf;
27 }
28 }
29}
30
31
32namespace dunedaq {
33 namespace timinglibs {
34 namespace dal {
35
40 class TimingHardwareManagerBase : public dunedaq::timinglibs::dal::TimingHardwareInterface, public dunedaq::confmodel::DaqModule {
41
43 friend class conffwk::DalObject;
44 friend class conffwk::DalFactory;
46
47 protected:
48
50 virtual ~TimingHardwareManagerBase() noexcept;
51 virtual void init(bool init_children);
52
53 public:
54
57 static const std::string& s_class_name;
58
59
69 virtual void print(unsigned int offset, bool print_header, std::ostream& s) const;
70
71
81 virtual std::vector<const dunedaq::conffwk::DalObject *> get(const std::string& name, bool upcast_unregistered = true) const;
82
83
84 protected:
85
86 bool get(const std::string& name, std::vector<const dunedaq::conffwk::DalObject *>& vec, bool upcast_unregistered, bool first_call) const;
87
88
89 private:
90
92
93
94 public:
95
96 // relationship names
97
98 inline static const std::string s_configuration = "configuration";
99
100 static const std::string& __get_configuration_str() noexcept { return s_configuration; }
101
102
111 {
112 std::lock_guard scoped_lock(m_mutex);
113 check();
114 check_init();
115 if (!m_configuration)
116 {
117 std::ostringstream text;
118 text << "relationship \"" << s_configuration << "\" of object " << this << " is not set";
119 throw dunedaq::conffwk::Generic(ERS_HERE, text.str().c_str());
120 }
121 return m_configuration;
122 }
123
124
131 void
133
134 };
135
136 // out stream operator
137
138 inline std::ostream& operator<<(std::ostream& s, const TimingHardwareManagerBase& obj)
139 {
140 return obj.print_object(s);
141 }
142
143 typedef std::vector<const TimingHardwareManagerBase*>::const_iterator TimingHardwareManagerBaseIterator;
144
145 }
146 }
147}
148
149#endif
#define ERS_HERE
The base class for any generated DAL object.
Definition DalObject.hpp:45
Configuration & configuration() const noexcept
std::mutex m_mutex
Used to protect changes of DAL 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...
Generic configuration exception.
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...
const dunedaq::timinglibs::dal::TimingHardwareManagerConf * m_configuration
TimingHardwareManagerBase(conffwk::DalRegistry &db, const conffwk::ConfigObject &obj) noexcept
void set_configuration(const dunedaq::timinglibs::dal::TimingHardwareManagerConf *value)
Set "configuration" relationship value.
const dunedaq::timinglibs::dal::TimingHardwareManagerConf * get_configuration() const
Get "configuration" relationship value.
conffwk entry point
double offset
std::ostream & operator<<(std::ostream &s, const EndpointLocation &obj)
std::vector< constTimingHardwareManagerBase * >::const_iterator TimingHardwareManagerBaseIterator
Including Qt Headers.