DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
dunedaq::confmodel::VirtualHost Class Reference

#include <VirtualHost.hpp>

Inheritance diagram for dunedaq::confmodel::VirtualHost:
[legend]
Collaboration diagram for dunedaq::confmodel::VirtualHost:
[legend]

Public Member Functions

virtual void print (unsigned int offset, bool print_header, std::ostream &s) const
 Print details of the VirtualHost object.
 
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 pointers.
 
const std::vector< const dunedaq::confmodel::HostComponent * > & get_uses () const
 Get "uses" relationship value. Hardware resources required by this virtual host.
 
void set_uses (const std::vector< const dunedaq::confmodel::HostComponent * > &value)
 Set "uses" relationship value. Hardware resources required by this virtual host.
 
const dunedaq::confmodel::PhysicalHostget_runs_on () const
 Get "runs_on" relationship value. The physical host that this virtual host runs on.
 
void set_runs_on (const dunedaq::confmodel::PhysicalHost *value)
 Set "runs_on" relationship value. The physical host that this virtual host runs on.
 
virtual void print (unsigned int offset, bool print_header, std::ostream &s) const
 Print details of the VirtualHost object.
 
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 pointers.
 
const std::vector< const dunedaq::confmodel::HostComponent * > & get_uses () const
 Get "uses" relationship value. Hardware resources required by this virtual host.
 
void set_uses (const std::vector< const dunedaq::confmodel::HostComponent * > &value)
 Set "uses" relationship value. Hardware resources required by this virtual host.
 
const dunedaq::confmodel::PhysicalHostget_runs_on () const
 Get "runs_on" relationship value. The physical host that this virtual host runs on.
 
void set_runs_on (const dunedaq::confmodel::PhysicalHost *value)
 Set "runs_on" relationship value. The physical host that this virtual host runs on.
 
- Public Member Functions inherited from dunedaq::conffwk::DalObject
const std::string & UID () const noexcept
 
const std::string & class_name () const noexcept
 
bool castable (const std::string &target) const noexcept
 
bool castable (const std::string *target) const noexcept
 
template<class TARGET >
const TARGET * cast () const noexcept
 Casts object to different class.
 
std::string full_name () const noexcept
 
const ConfigObjectconfig_object () const
 
DalRegistryregistry () const noexcept
 
Configurationconfiguration () const noexcept
 
void unread ()
 
void set (const ConfigObject &o) noexcept
 
void move (const std::string &at)
 
void rename (const std::string &new_id)
 
void p_hdr (std::ostream &s, unsigned int indent, const std::string &cl, const char *nm=nullptr) const
 print object headers
 
std::ostream & print_object (std::ostream &s) const
 print object details
 
void throw_init_ex (dunedaq::conffwk::Exception &ex)
 throw object initialisation exception (i.e.
 

Static Public Member Functions

static const std::string & __get_uses_str () noexcept
 
static const std::string & __get_runs_on_str () noexcept
 
static const std::string & __get_uses_str () noexcept
 
static const std::string & __get_runs_on_str () noexcept
 
- Static Public Member Functions inherited from dunedaq::conffwk::DalObject
static void p_null (std::ostream &s)
 print "(null)"
 
static void p_rm (std::ostream &s)
 print "(deleted object)"
 
static void p_error (std::ostream &s, dunedaq::conffwk::Exception &ex)
 print error text
 
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.
 
static bool is_null (const DalObject *ref) noexcept
 check a pointer on DAL object is null
 

Static Public Attributes

static const std::string & s_class_name
 
static const std::string s_uses = "uses"
 
static const std::string s_runs_on = "runs_on"
 

Protected Member Functions

 VirtualHost (conffwk::DalRegistry &db, const conffwk::ConfigObject &obj) noexcept
 
virtual ~VirtualHost () noexcept
 
virtual void init (bool init_children)
 
bool get (const std::string &name, std::vector< const dunedaq::conffwk::DalObject * > &vec, bool upcast_unregistered, bool first_call) const
 
 VirtualHost (conffwk::DalRegistry &db, const conffwk::ConfigObject &obj) noexcept
 
virtual ~VirtualHost () noexcept
 
virtual void init (bool init_children)
 
bool get (const std::string &name, std::vector< const dunedaq::conffwk::DalObject * > &vec, bool upcast_unregistered, bool first_call) const
 
- Protected Member Functions inherited from dunedaq::conffwk::DalObject
 DalObject (DalRegistry &db, const ConfigObject &o) noexcept
 
virtual ~DalObject ()
 
void clear () noexcept
 
void check () const
 
bool is_deleted () const
 
void increment_created () noexcept
 
void increment_read () noexcept
 
void check_init () const
 Check and initialize object if necessary.
 
template<typename T >
void _set_object (const std::string &name, const T *value)
 Helper method for generated set single-value relationship methods.
 
template<typename T >
void _set_objects (const std::string &name, const std::vector< const T * > &value)
 Helper method for generated set multi-value relationship methods.
 
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.
 
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.
 

Private Attributes

std::vector< const dunedaq::confmodel::HostComponent * > m_uses
 
const dunedaq::confmodel::PhysicalHostm_runs_on
 

Friends

class conffwk::Configuration
 
class conffwk::DalObject
 
class conffwk::DalFactory
 
class conffwk::DalRegistry
 

Additional Inherited Members

- Protected Attributes inherited from dunedaq::conffwk::DalObject
std::mutex m_mutex
 Used to protect changes of DAL object.
 
bool p_was_read
 is true, if the object was read
 
DalRegistryp_registry
 Configuration object.
 
ConfigObject p_obj
 Config object used by given template object.
 
std::string p_UID
 Is used for template objects (see dqm_conffwk)
 

Detailed Description

Definition at line 30 of file VirtualHost.hpp.

Constructor & Destructor Documentation

◆ VirtualHost() [1/2]

dunedaq::confmodel::VirtualHost::VirtualHost ( conffwk::DalRegistry & db,
const conffwk::ConfigObject & obj )
protectednoexcept

Definition at line 32 of file VirtualHost.cpp.

32 :
34 m_runs_on (nullptr)
35
36 {
37 ;
38 }
The base class for any generated DAL object.
Definition DalObject.hpp:45
const dunedaq::confmodel::PhysicalHost * m_runs_on

◆ ~VirtualHost() [1/2]

dunedaq::confmodel::VirtualHost::~VirtualHost ( )
protectedvirtualnoexcept

Definition at line 78 of file VirtualHost.cpp.

79 {
80 }

◆ VirtualHost() [2/2]

dunedaq::confmodel::VirtualHost::VirtualHost ( conffwk::DalRegistry & db,
const conffwk::ConfigObject & obj )
protectednoexcept

◆ ~VirtualHost() [2/2]

virtual dunedaq::confmodel::VirtualHost::~VirtualHost ( )
protectedvirtualnoexcept

Member Function Documentation

◆ __get_runs_on_str() [1/2]

static const std::string & dunedaq::confmodel::VirtualHost::__get_runs_on_str ( )
inlinestaticnoexcept

Definition at line 93 of file VirtualHost.hpp.

93{ return s_runs_on; }
static const std::string s_runs_on

◆ __get_runs_on_str() [2/2]

static const std::string & dunedaq::confmodel::VirtualHost::__get_runs_on_str ( )
inlinestaticnoexcept

Definition at line 93 of file VirtualHost.hpp.

93{ return s_runs_on; }

◆ __get_uses_str() [1/2]

static const std::string & dunedaq::confmodel::VirtualHost::__get_uses_str ( )
inlinestaticnoexcept

Definition at line 92 of file VirtualHost.hpp.

92{ return s_uses; }
static const std::string s_uses

◆ __get_uses_str() [2/2]

static const std::string & dunedaq::confmodel::VirtualHost::__get_uses_str ( )
inlinestaticnoexcept

Definition at line 92 of file VirtualHost.hpp.

92{ return s_uses; }

◆ get() [1/4]

std::vector< const dunedaq::conffwk::DalObject * > dunedaq::confmodel::VirtualHost::get ( const std::string & name,
bool upcast_unregistered = true ) const
virtual

Get values of relationships and results of some algorithms as a vector of dunedaq::conffwk::DalObject pointers.

Parameters are:

Parameters
namename of the relationship or algorithm
Returns
value of relationship or result of algorithm
Exceptions
std::exceptionif there is no relationship or algorithm with such name in this and base classes

Implements dunedaq::conffwk::DalObject.

Reimplemented in dunedaq::appmodel::ReadoutHost, and dunedaq::appmodel::ReadoutHost.

Definition at line 82 of file VirtualHost.cpp.

83 {
84 std::vector<const dunedaq::conffwk::DalObject *> vec;
85
86 if (!get(name, vec, upcast_unregistered, true))
87 throw_get_ex(name, s_class_name, this);
88
89 return vec;
90 }
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
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_class_name

◆ get() [2/4]

virtual std::vector< const dunedaq::conffwk::DalObject * > dunedaq::confmodel::VirtualHost::get ( const std::string & name,
bool upcast_unregistered = true ) const
virtual

Get values of relationships and results of some algorithms as a vector of dunedaq::conffwk::DalObject pointers.

Parameters are:

Parameters
namename of the relationship or algorithm
Returns
value of relationship or result of algorithm
Exceptions
std::exceptionif there is no relationship or algorithm with such name in this and base classes

Implements dunedaq::conffwk::DalObject.

Reimplemented in dunedaq::appmodel::ReadoutHost, and dunedaq::appmodel::ReadoutHost.

◆ get() [3/4]

bool dunedaq::confmodel::VirtualHost::get ( const std::string & name,
std::vector< const dunedaq::conffwk::DalObject * > & vec,
bool upcast_unregistered,
bool first_call ) const
protected

Definition at line 92 of file VirtualHost.cpp.

93 {
94 if (first_call)
95 {
96 std::lock_guard scoped_lock(m_mutex);
97
98 check();
99 check_init();
100
101 if (get_rel_objects(name, upcast_unregistered, vec))
102 return true;
103 }
104
105 if (first_call)
106 return get_algo_objects(name, vec);
107
108 return false;
109 }
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
std::mutex m_mutex
Used to protect changes of DAL object.
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.

◆ get() [4/4]

bool dunedaq::confmodel::VirtualHost::get ( const std::string & name,
std::vector< const dunedaq::conffwk::DalObject * > & vec,
bool upcast_unregistered,
bool first_call ) const
protected

◆ get_runs_on() [1/2]

const dunedaq::confmodel::PhysicalHost * dunedaq::confmodel::VirtualHost::get_runs_on ( ) const
inline

Get "runs_on" relationship value. The physical host that this virtual host runs on.

Returns
the relationship value
Exceptions
dunedaq::conffwk::Generic,dunedaq::conffwk::DeletedObject

Definition at line 137 of file VirtualHost.hpp.

138 {
139 std::lock_guard scoped_lock(m_mutex);
140 check();
141 check_init();
142 if (!m_runs_on)
143 {
144 std::ostringstream text;
145 text << "relationship \"" << s_runs_on << "\" of object " << this << " is not set";
146 throw dunedaq::conffwk::Generic(ERS_HERE, text.str().c_str());
147 }
148 return m_runs_on;
149 }
#define ERS_HERE
Generic configuration exception.

◆ get_runs_on() [2/2]

const dunedaq::confmodel::PhysicalHost * dunedaq::confmodel::VirtualHost::get_runs_on ( ) const
inline

Get "runs_on" relationship value. The physical host that this virtual host runs on.

Returns
the relationship value
Exceptions
dunedaq::conffwk::Generic,dunedaq::conffwk::DeletedObject

Definition at line 137 of file VirtualHost.hpp.

138 {
139 std::lock_guard scoped_lock(m_mutex);
140 check();
141 check_init();
142 if (!m_runs_on)
143 {
144 std::ostringstream text;
145 text << "relationship \"" << s_runs_on << "\" of object " << this << " is not set";
146 throw dunedaq::conffwk::Generic(ERS_HERE, text.str().c_str());
147 }
148 return m_runs_on;
149 }

◆ get_uses() [1/2]

const std::vector< const dunedaq::confmodel::HostComponent * > & dunedaq::confmodel::VirtualHost::get_uses ( ) const
inline

Get "uses" relationship value. Hardware resources required by this virtual host.

Returns
the relationship value
Exceptions
dunedaq::conffwk::Generic,dunedaq::conffwk::DeletedObject

Definition at line 104 of file VirtualHost.hpp.

105 {
106 std::lock_guard scoped_lock(m_mutex);
107 check();
108 check_init();
109 if (m_uses.empty())
110 {
111 std::ostringstream text;
112 text << "relationship \"" << s_uses << "\" of object " << this << " is empty";
113 throw dunedaq::conffwk::Generic(ERS_HERE, text.str().c_str());
114 }
115 return m_uses;
116 }
std::vector< const dunedaq::confmodel::HostComponent * > m_uses

◆ get_uses() [2/2]

const std::vector< const dunedaq::confmodel::HostComponent * > & dunedaq::confmodel::VirtualHost::get_uses ( ) const
inline

Get "uses" relationship value. Hardware resources required by this virtual host.

Returns
the relationship value
Exceptions
dunedaq::conffwk::Generic,dunedaq::conffwk::DeletedObject

Definition at line 104 of file VirtualHost.hpp.

105 {
106 std::lock_guard scoped_lock(m_mutex);
107 check();
108 check_init();
109 if (m_uses.empty())
110 {
111 std::ostringstream text;
112 text << "relationship \"" << s_uses << "\" of object " << this << " is empty";
113 throw dunedaq::conffwk::Generic(ERS_HERE, text.str().c_str());
114 }
115 return m_uses;
116 }

◆ init() [1/2]

void dunedaq::confmodel::VirtualHost::init ( bool init_children)
protectedvirtual

Initialize object (method generated by genconffwk)

Parameters
init_childrenif true, initialize referenced objects

Implements dunedaq::conffwk::DalObject.

Reimplemented in dunedaq::appmodel::ReadoutHost, and dunedaq::appmodel::ReadoutHost.

Definition at line 63 of file VirtualHost.cpp.

64 {
65 p_was_read = true;
67 TLOG_DEBUG(5) << "read object " << this << " (class " << s_class_name << ')';
68
69 try {
72 }
73 catch (dunedaq::conffwk::Exception & ex) {
74 throw_init_ex(ex);
75 }
76 }
void throw_init_ex(dunedaq::conffwk::Exception &ex)
throw object initialisation exception (i.e.
Definition DalObject.cpp:74
void increment_read() noexcept
DalRegistry & p_registry
Configuration object.
bool p_was_read
is true, if the object was read
ConfigObject p_obj
Config object used by given template object.
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

◆ init() [2/2]

virtual void dunedaq::confmodel::VirtualHost::init ( bool init_children)
protectedvirtual

Initialize object (method generated by genconffwk)

Parameters
init_childrenif true, initialize referenced objects

Implements dunedaq::conffwk::DalObject.

Reimplemented in dunedaq::appmodel::ReadoutHost, and dunedaq::appmodel::ReadoutHost.

◆ print() [1/2]

void dunedaq::confmodel::VirtualHost::print ( unsigned int offset,
bool print_header,
std::ostream & s ) const
virtual

Print details of the VirtualHost object.

Parameters are:

Parameters
offsetnumber of spaces to shift object right (useful to print nested objects)
print_headerif false, do not print object header (to print attributes of base classes)
soutput stream

Implements dunedaq::conffwk::DalObject.

Reimplemented in dunedaq::appmodel::ReadoutHost, and dunedaq::appmodel::ReadoutHost.

Definition at line 41 of file VirtualHost.cpp.

42 {
43 check_init();
44
45 try {
46 const std::string str(indent+2, ' ');
47
48 if (print_header)
49 p_hdr(s, indent, s_class_name, "dunedaq::confmodel");
50
51
52 // print direct relationships
53
56 }
57 catch (dunedaq::conffwk::Exception & ex) {
59 }
60 }
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
static void p_error(std::ostream &s, dunedaq::conffwk::Exception &ex)
print error text
Definition DalObject.cpp:59
void p_sv_rel(std::ostream &s, const std::string &str, const std::string &name, const DalObject *obj)
print weak single-value relationship
void p_mv_rel(std::ostream &s, const std::string &str, const std::string &name, const T &objs) noexcept
print weak multi-value relationship

◆ print() [2/2]

virtual void dunedaq::confmodel::VirtualHost::print ( unsigned int offset,
bool print_header,
std::ostream & s ) const
virtual

Print details of the VirtualHost object.

Parameters are:

Parameters
offsetnumber of spaces to shift object right (useful to print nested objects)
print_headerif false, do not print object header (to print attributes of base classes)
soutput stream

Implements dunedaq::conffwk::DalObject.

Reimplemented in dunedaq::appmodel::ReadoutHost, and dunedaq::appmodel::ReadoutHost.

◆ set_runs_on() [1/2]

void dunedaq::confmodel::VirtualHost::set_runs_on ( const dunedaq::confmodel::PhysicalHost * value)

Set "runs_on" relationship value. The physical host that this virtual host runs on.

Parameters
valuenew relationship value
Exceptions
dunedaq::conffwk::Generic,dunedaq::conffwk::DeletedObject

Definition at line 116 of file VirtualHost.cpp.

117 {
118 _set_object(s_runs_on, value);
119 }
void _set_object(const std::string &name, const T *value)
Helper method for generated set single-value relationship methods.

◆ set_runs_on() [2/2]

void dunedaq::confmodel::VirtualHost::set_runs_on ( const dunedaq::confmodel::PhysicalHost * value)

Set "runs_on" relationship value. The physical host that this virtual host runs on.

Parameters
valuenew relationship value
Exceptions
dunedaq::conffwk::Generic,dunedaq::conffwk::DeletedObject

◆ set_uses() [1/2]

void dunedaq::confmodel::VirtualHost::set_uses ( const std::vector< const dunedaq::confmodel::HostComponent * > & value)

Set "uses" relationship value. Hardware resources required by this virtual host.

Parameters
valuenew relationship value
Exceptions
dunedaq::conffwk::Generic,dunedaq::conffwk::DeletedObject

Definition at line 111 of file VirtualHost.cpp.

112 {
113 _set_objects(s_uses, value);
114 }
void _set_objects(const std::string &name, const std::vector< const T * > &value)
Helper method for generated set multi-value relationship methods.

◆ set_uses() [2/2]

void dunedaq::confmodel::VirtualHost::set_uses ( const std::vector< const dunedaq::confmodel::HostComponent * > & value)

Set "uses" relationship value. Hardware resources required by this virtual host.

Parameters
valuenew relationship value
Exceptions
dunedaq::conffwk::Generic,dunedaq::conffwk::DeletedObject

Friends And Related Symbol Documentation

◆ conffwk::Configuration

Definition at line 32 of file VirtualHost.hpp.

◆ conffwk::DalFactory

conffwk::DalFactory
friend

Definition at line 34 of file VirtualHost.hpp.

◆ conffwk::DalObject

Definition at line 33 of file VirtualHost.hpp.

◆ conffwk::DalRegistry

Definition at line 35 of file VirtualHost.hpp.

Member Data Documentation

◆ m_runs_on

const dunedaq::confmodel::PhysicalHost * dunedaq::confmodel::VirtualHost::m_runs_on
private

Definition at line 82 of file VirtualHost.hpp.

◆ m_uses

std::vector< const dunedaq::confmodel::HostComponent * > dunedaq::confmodel::VirtualHost::m_uses
private

Definition at line 81 of file VirtualHost.hpp.

◆ s_class_name

static const std::string & dunedaq::confmodel::VirtualHost::s_class_name
static

The name of the configuration class.

Definition at line 47 of file VirtualHost.hpp.

◆ s_runs_on

static const std::string dunedaq::confmodel::VirtualHost::s_runs_on = "runs_on"
inlinestatic

Definition at line 90 of file VirtualHost.hpp.

◆ s_uses

static const std::string dunedaq::confmodel::VirtualHost::s_uses = "uses"
inlinestatic

Definition at line 89 of file VirtualHost.hpp.


The documentation for this class was generated from the following files: