DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
RCApplication.hpp
Go to the documentation of this file.
1// *** this file is generated by oksdalgen, do not modify it ***
2
3#ifndef _RCApplication_0_dunedaq__confmodel_0_confmodel_H_
4#define _RCApplication_0_dunedaq__confmodel_0_confmodel_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
19
20 // forward declaration for classes used in relationships and algorithms
21
22namespace dunedaq {
23 namespace confmodel {
24 class FSMconfiguration;
25 class RCBroadcaster;
26 class Session;
27 }
28}
29
30
31namespace dunedaq {
32 namespace confmodel {
33
38 class RCApplication : public dunedaq::confmodel::Application {
39
41 friend class conffwk::DalObject;
42 friend class conffwk::DalFactory;
44
45 protected:
46
48 virtual ~RCApplication() noexcept;
49 virtual void init(bool init_children);
50
51 public:
52
55 static const std::string& s_class_name;
56
57
67 virtual void print(unsigned int offset, bool print_header, std::ostream& s) const;
68
69
79 virtual std::vector<const dunedaq::conffwk::DalObject *> get(const std::string& name, bool upcast_unregistered = true) const;
80
81
82 protected:
83
84 bool get(const std::string& name, std::vector<const dunedaq::conffwk::DalObject *>& vec, bool upcast_unregistered, bool first_call) const;
85
86
87 private:
88
92
93
94 public:
95
96 // attribute names
97
98 inline static const std::string s_application_name = "application_name";
99
100 static const std::string& __get_application_name_str() noexcept { return s_application_name; }
101
102
109 const std::string&
111 {
112 std::lock_guard scoped_lock(m_mutex);
113 check();
114 check_init();
115 return m_application_name;
116 }
117
124 void
125 set_application_name(const std::string& value)
126 {
127 std::lock_guard scoped_lock(m_mutex);
128 check();
129 clear();
131 }
132
133
134 // relationship names
135
136 inline static const std::string s_fsm = "fsm";
137 inline static const std::string s_broadcaster = "broadcaster";
138
139 static const std::string& __get_fsm_str() noexcept { return s_fsm; }
140 static const std::string& __get_broadcaster_str() noexcept { return s_broadcaster; }
141
142
150 get_fsm() const
151 {
152 std::lock_guard scoped_lock(m_mutex);
153 check();
154 check_init();
155 if (!m_fsm)
156 {
157 std::ostringstream text;
158 text << "relationship \"" << s_fsm << "\" of object " << this << " is not set";
159 throw dunedaq::conffwk::Generic(ERS_HERE, text.str().c_str());
160 }
161 return m_fsm;
162 }
163
164
171 void
173
182 {
183 std::lock_guard scoped_lock(m_mutex);
184 check();
185 check_init();
186 return m_broadcaster;
187 }
188
189
196 void
198
199
200 public:
201
202 // user-defined algorithms
203
208 const std::vector<std::string> construct_commandline_parameters(const conffwk::Configuration& confdb, const dunedaq::confmodel::Session* session) const;
209 };
210
211 // out stream operator
212
213 inline std::ostream& operator<<(std::ostream& s, const RCApplication& obj)
214 {
215 return obj.print_object(s);
216 }
217
218 typedef std::vector<const RCApplication*>::const_iterator RCApplicationIterator;
219
220 }
221}
222
223#endif
#define ERS_HERE
void set_by_ref(const std::string &name, T &value)
Set attribute value.
The base class for any generated DAL object.
Definition DalObject.hpp:45
std::mutex m_mutex
Used to protect changes of DAL object.
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...
Generic configuration exception.
const std::string & get_application_name() const
Get "application_name" attribute value.
static const std::string s_broadcaster
virtual void init(bool init_children)
RCApplication(conffwk::DalRegistry &db, const conffwk::ConfigObject &obj) noexcept
const dunedaq::confmodel::FSMconfiguration * m_fsm
const dunedaq::confmodel::RCBroadcaster * m_broadcaster
void set_broadcaster(const dunedaq::confmodel::RCBroadcaster *value)
Set "broadcaster" relationship value.
static const std::string s_application_name
static const std::string & __get_fsm_str() noexcept
static const std::string & __get_broadcaster_str() noexcept
void set_application_name(const std::string &value)
Set "application_name" attribute value.
static const std::string s_fsm
const dunedaq::confmodel::FSMconfiguration * get_fsm() const
Get "fsm" relationship value.
void set_fsm(const dunedaq::confmodel::FSMconfiguration *value)
Set "fsm" relationship value.
const dunedaq::confmodel::RCBroadcaster * get_broadcaster() const
Get "broadcaster" 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...
const std::vector< std::string > construct_commandline_parameters(const conffwk::Configuration &confdb, const dunedaq::confmodel::Session *session) const
static const std::string & __get_application_name_str() noexcept
static const std::string & s_class_name
conffwk entry point
double offset
std::vector< constRCApplication * >::const_iterator RCApplicationIterator
std::ostream & operator<<(std::ostream &s, const ActionPlan &obj)
Including Qt Headers.