DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
RandomListGeneratorSet.hpp
Go to the documentation of this file.
1// *** this file is generated by oksdalgen, do not modify it ***
2
3#ifndef _RandomListGeneratorSet_0_dunedaq__listrev__dal_0_listrev_dal_H_
4#define _RandomListGeneratorSet_0_dunedaq__listrev__dal_0_listrev_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
17 // forward declaration for classes used in relationships and algorithms
18
19namespace dunedaq {
20 namespace listrev {
21 namespace dal {
22 class RandomDataListGenerator;
23 }
24 }
25}
26
27
28namespace dunedaq {
29 namespace listrev {
30 namespace dal {
31
33
34 friend class conffwk::Configuration;
35 friend class conffwk::DalObject;
36 friend class conffwk::DalFactory;
37 friend class conffwk::DalRegistry;
38
39 protected:
40
42 virtual ~RandomListGeneratorSet() noexcept;
43 virtual void init(bool init_children);
44
45 public:
46
49 static const std::string& s_class_name;
50
51
61 virtual void print(unsigned int offset, bool print_header, std::ostream& s) const;
62
63
73 virtual std::vector<const dunedaq::conffwk::DalObject *> get(const std::string& name, bool upcast_unregistered = true) const;
74
75
76 protected:
77
78 bool get(const std::string& name, std::vector<const dunedaq::conffwk::DalObject *>& vec, bool upcast_unregistered, bool first_call) const;
79
80
81 private:
82
84
85
86 public:
87
88 // relationship names
89
90 inline static const std::string s_generators = "generators";
91
92 static const std::string& __get_generators_str() noexcept { return s_generators; }
93
94
101 const std::vector<const dunedaq::listrev::dal::RandomDataListGenerator*>&
103 {
104 std::lock_guard scoped_lock(m_mutex);
105 check();
106 check_init();
107 if (m_generators.empty())
108 {
109 std::ostringstream text;
110 text << "relationship \"" << s_generators << "\" of object " << this << " is empty";
111 throw dunedaq::conffwk::Generic(ERS_HERE, text.str().c_str());
112 }
113 return m_generators;
114 }
115
116
123 void
124 set_generators(const std::vector<const dunedaq::listrev::dal::RandomDataListGenerator*>& value);
125
126 };
127
128 // out stream operator
129
130 inline std::ostream& operator<<(std::ostream& s, const RandomListGeneratorSet& obj)
131 {
132 return obj.print_object(s);
133 }
134
135 typedef std::vector<const RandomListGeneratorSet*>::const_iterator RandomListGeneratorSetIterator;
136
137 }
138 }
139}
140
141#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.
RandomListGeneratorSet(conffwk::DalRegistry &db, const conffwk::ConfigObject &obj) noexcept
static const std::string & __get_generators_str() noexcept
void set_generators(const std::vector< const dunedaq::listrev::dal::RandomDataListGenerator * > &value)
Set "generators" 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< const dunedaq::listrev::dal::RandomDataListGenerator * > & get_generators() const
Get "generators" relationship value.
std::vector< const dunedaq::listrev::dal::RandomDataListGenerator * > m_generators
conffwk entry point
double offset
std::ostream & operator<<(std::ostream &s, const ListReverser &obj)
std::vector< constRandomListGeneratorSet * >::const_iterator RandomListGeneratorSetIterator
Including Qt Headers.