MarlinMT
0.1.0
|
IScheduler interface Interface for implementing a scheduling algorithm for event processing. More...
#include <IScheduler.h>
Inherits marlinmt::Component.
Inherited by marlinmt::concurrency::PEPScheduler, and marlinmt::SimpleScheduler.
Public Member Functions | |
IScheduler () | |
Constructor. More... | |
virtual | ~IScheduler ()=default |
virtual void | initialize () override |
Initialize the scheduler. More... | |
virtual void | end ()=0 |
Terminate the scheduler activites Cleanup memory, etc ... More... | |
virtual void | processRunHeader (std::shared_ptr< RunHeader > rhdr)=0 |
Process a run header. More... | |
virtual void | pushEvent (std::shared_ptr< EventStore > event)=0 |
Push a new event to the scheduler for processing. More... | |
virtual void | popFinishedEvents (std::vector< std::shared_ptr< EventStore >> &events)=0 |
Retrieve finished events from the scheduler. More... | |
virtual std::size_t | freeSlots () const =0 |
Get the number of free event slots. More... | |
![]() | |
Component ()=delete | |
No default constructor. More... | |
Component (const Component &)=delete | |
No copy or assignement. More... | |
Component & | operator= (const Component &)=delete |
virtual | ~Component ()=default |
Default destructor. More... | |
Component (const std::string &type) | |
Constructor with component type. More... | |
const std::string & | type () const |
Get the component name. More... | |
const std::string & | name () const |
Get the component name. More... | |
void | setName (const std::string &n) |
Set the component name. More... | |
const std::string & | description () const |
Get the component description. More... | |
void | setDescription (const std::string &desc) |
Set the component description. More... | |
const Application & | application () const |
Get the application in which the component is registered. More... | |
Application & | application () |
Get the application in which the component is registered. More... | |
template<class T > | |
Logging::StreamType | log () const |
Log a message with specific log level. More... | |
Logging::StreamType | debug () const |
Shortcut for log<DEBUG>() More... | |
Logging::StreamType | message () const |
Shortcut for log<MESSAGE>() More... | |
Logging::StreamType | warning () const |
Shortcut for log<WARNING>() More... | |
Logging::StreamType | error () const |
Shortcut for log<ERROR>() More... | |
void | setVerbosity (const std::string &level) |
Set the verbosity level. More... | |
const std::string & | verbosity () const |
Get the verbosity level. More... | |
bool | isInitialized () const |
Whether the component has been initialized. More... | |
void | setup (Application *app) |
Setup the component. More... | |
void | printParameters () const |
Print the component parameters. More... | |
template<class T > | |
void | printParameters () const |
Print the component parameters at specific verbosity. More... | |
void | setParameters (const ConfigSection §ion, bool throwIfNotFound=false) |
Set the parameters from the configuration section. More... | |
void | getParameters (ConfigSection §ion, const std::set< std::string > &exclude={}) const |
Get the parameters from configurable object and populate the config section with. More... | |
![]() | |
Configurable ()=default | |
virtual | ~Configurable ()=default |
template<typename T > | |
std::shared_ptr< ParameterImpl > | addParameter (EParameterType paramType, const std::string &name, const std::string &desc, std::shared_ptr< T > value) |
Add a parameter. More... | |
template<typename T > | |
std::shared_ptr< ParameterImpl > | addParameter (EParameterType paramType, const std::string &name, const std::string &desc, std::shared_ptr< T > value, T defVal) |
Add a parameter. More... | |
template<typename T > | |
T | parameter (const std::string &name) const |
Get a parameter value. More... | |
template<typename T > | |
T | parameter (const std::string &name, const T &fallback) const |
Get a parameter value. More... | |
void | checkParameter (const std::string &name) const |
Check if the parameter has been registered. More... | |
bool | exists (const std::string &name) const |
Return true if the parameter has been registered. More... | |
bool | isSet (const std::string &name) const |
Returns true if the parameter exists and is set, false otherwise. More... | |
void | clear () |
Remove all parameters. More... | |
void | unset () |
Unset all registered parameters. More... | |
iterator | begin () |
const_iterator | begin () const |
iterator | end () |
const_iterator | end () const |
Additional Inherited Members | |
![]() | |
using | LoggerPtr = Logging::Logger |
![]() | |
using | ParameterMap = std::map< std::string, std::shared_ptr< ParameterImpl > > |
using | iterator = ParameterMap::iterator |
using | const_iterator = ParameterMap::const_iterator |
![]() | |
std::string | _type {} |
The component type. More... | |
std::string | _name {} |
The component name. More... | |
std::string | _description {"No description"} |
The component description. More... | |
Application * | _application {nullptr} |
The application in which the component has been registered. More... | |
LoggerPtr | _logger {nullptr} |
The logger instance. More... | |
StringParameter | _verbosity { *this, "Verbosity", "The component verbosity level", "MESSAGE" } |
The verbosity level of the logger (parameter) More... | |
![]() | |
ParameterMap | _parameters {} |
The parameter map. More... | |
IScheduler interface Interface for implementing a scheduling algorithm for event processing.
The scheduling can be sequential or parallel (inter-event / intra-event / both). See implementation classes for more details.
Definition at line 23 of file IScheduler.h.
marlinmt::IScheduler::IScheduler | ( | ) |
Constructor.
Definition at line 8 of file IScheduler.cc.
|
virtualdefault |
|
pure virtual |
Terminate the scheduler activites Cleanup memory, etc ...
Implemented in marlinmt::concurrency::PEPScheduler, and marlinmt::SimpleScheduler.
|
pure virtual |
Get the number of free event slots.
Implemented in marlinmt::concurrency::PEPScheduler, and marlinmt::SimpleScheduler.
|
overridevirtual |
Initialize the scheduler.
Read the config section from the configuration
Reimplemented from marlinmt::Component.
Reimplemented in marlinmt::concurrency::PEPScheduler, and marlinmt::SimpleScheduler.
Definition at line 15 of file IScheduler.cc.
References marlinmt::Component::application(), marlinmt::Application::configuration(), and marlinmt::Component::setParameters().
Referenced by marlinmt::SimpleScheduler::initialize(), and marlinmt::concurrency::PEPScheduler::initialize().
|
pure virtual |
Retrieve finished events from the scheduler.
events | the list of event to retrieve |
Implemented in marlinmt::concurrency::PEPScheduler, and marlinmt::SimpleScheduler.
|
pure virtual |
Process a run header.
rhdr | the run header to process |
Implemented in marlinmt::concurrency::PEPScheduler, and marlinmt::SimpleScheduler.
|
pure virtual |
Push a new event to the scheduler for processing.
event | the event to push |
Implemented in marlinmt::concurrency::PEPScheduler, and marlinmt::SimpleScheduler.