DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
PhysicalHost.hpp
Go to the documentation of this file.
1// *** this file is generated by oksdalgen, do not modify it ***
2
3#ifndef _PhysicalHost_0_dunedaq__confmodel_0_confmodel_H_
4#define _PhysicalHost_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
17 // forward declaration for classes used in relationships and algorithms
18
19namespace dunedaq {
20 namespace confmodel {
21 class HostComponent;
22 }
23}
24
25
26namespace dunedaq {
27 namespace confmodel {
28
30
31 friend class conffwk::Configuration;
32 friend class conffwk::DalObject;
33 friend class conffwk::DalFactory;
34 friend class conffwk::DalRegistry;
35
36 protected:
37
39 virtual ~PhysicalHost() noexcept;
40 virtual void init(bool init_children);
41
42 public:
43
46 static const std::string& s_class_name;
47
48
58 virtual void print(unsigned int offset, bool print_header, std::ostream& s) const;
59
60
70 virtual std::vector<const dunedaq::conffwk::DalObject *> get(const std::string& name, bool upcast_unregistered = true) const;
71
72
73 protected:
74
75 bool get(const std::string& name, std::vector<const dunedaq::conffwk::DalObject *>& vec, bool upcast_unregistered, bool first_call) const;
76
77
78 private:
79
81
82
83 public:
84
85 // relationship names
86
87 inline static const std::string s_contains = "contains";
88
89 static const std::string& __get_contains_str() noexcept { return s_contains; }
90
91
99 const std::vector<const dunedaq::confmodel::HostComponent*>&
101 {
102 std::lock_guard scoped_lock(m_mutex);
103 check();
104 check_init();
105 if (m_contains.empty())
106 {
107 std::ostringstream text;
108 text << "relationship \"" << s_contains << "\" of object " << this << " is empty";
109 throw dunedaq::conffwk::Generic(ERS_HERE, text.str().c_str());
110 }
111 return m_contains;
112 }
113
114
122 void
123 set_contains(const std::vector<const dunedaq::confmodel::HostComponent*>& value);
124
125 };
126
127 // out stream operator
128
129 inline std::ostream& operator<<(std::ostream& s, const PhysicalHost& obj)
130 {
131 return obj.print_object(s);
132 }
133
134 typedef std::vector<const PhysicalHost*>::const_iterator PhysicalHostIterator;
135
136 }
137}
138
139#endif
#define ERS_HERE
The base class for any generated DAL object.
Definition DalObject.hpp:45
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 ~PhysicalHost() noexcept
PhysicalHost(conffwk::DalRegistry &db, const conffwk::ConfigObject &obj) noexcept
virtual void init(bool init_children)
static const std::string & s_class_name
void set_contains(const std::vector< const dunedaq::confmodel::HostComponent * > &value)
Set "contains" relationship value. List of hardware components on this host.
const std::vector< const dunedaq::confmodel::HostComponent * > & get_contains() const
Get "contains" relationship value. List of hardware components on this host.
std::vector< const dunedaq::confmodel::HostComponent * > m_contains
friend class conffwk::DalFactory
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...
friend class conffwk::DalObject
static const std::string s_contains
static const std::string & __get_contains_str() noexcept
conffwk entry point
double offset
std::vector< constPhysicalHost * >::const_iterator PhysicalHostIterator
std::ostream & operator<<(std::ostream &s, const ActionPlan &obj)
Including Qt Headers.