MarlinMT  0.1.0
marlinmt::IScheduler Class Referenceabstract

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...
 
- Public Member Functions inherited from marlinmt::Component
 Component ()=delete
 No default constructor. More...
 
 Component (const Component &)=delete
 No copy or assignement. More...
 
Componentoperator= (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 Applicationapplication () const
 Get the application in which the component is registered. More...
 
Applicationapplication ()
 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 &section, bool throwIfNotFound=false)
 Set the parameters from the configuration section. More...
 
void getParameters (ConfigSection &section, const std::set< std::string > &exclude={}) const
 Get the parameters from configurable object and populate the config section with. More...
 
- Public Member Functions inherited from marlinmt::Configurable
 Configurable ()=default
 
virtual ~Configurable ()=default
 
template<typename T >
std::shared_ptr< ParameterImpladdParameter (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< ParameterImpladdParameter (EParameterType paramType, const std::string &name, const std::string &desc, std::shared_ptr< T > value, T defVal)
 Add a parameter. More...
 
template<typename T >
parameter (const std::string &name) const
 Get a parameter value. More...
 
template<typename 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

- Public Types inherited from marlinmt::Component
using LoggerPtr = Logging::Logger
 
- Public Types inherited from marlinmt::Configurable
using ParameterMap = std::map< std::string, std::shared_ptr< ParameterImpl > >
 
using iterator = ParameterMap::iterator
 
using const_iterator = ParameterMap::const_iterator
 
- Protected Attributes inherited from marlinmt::Component
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...
 
- Protected Attributes inherited from marlinmt::Configurable
ParameterMap _parameters {}
 The parameter map. More...
 

Detailed Description

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.

Constructor & Destructor Documentation

◆ IScheduler()

marlinmt::IScheduler::IScheduler ( )

Constructor.

Definition at line 8 of file IScheduler.cc.

◆ ~IScheduler()

virtual marlinmt::IScheduler::~IScheduler ( )
virtualdefault

Member Function Documentation

◆ end()

virtual void marlinmt::IScheduler::end ( )
pure virtual

Terminate the scheduler activites Cleanup memory, etc ...

Implemented in marlinmt::concurrency::PEPScheduler, and marlinmt::SimpleScheduler.

◆ freeSlots()

virtual std::size_t marlinmt::IScheduler::freeSlots ( ) const
pure virtual

Get the number of free event slots.

Implemented in marlinmt::concurrency::PEPScheduler, and marlinmt::SimpleScheduler.

◆ initialize()

void marlinmt::IScheduler::initialize ( )
overridevirtual

◆ popFinishedEvents()

virtual void marlinmt::IScheduler::popFinishedEvents ( std::vector< std::shared_ptr< EventStore >> &  events)
pure virtual

Retrieve finished events from the scheduler.

Parameters
eventsthe list of event to retrieve

Implemented in marlinmt::concurrency::PEPScheduler, and marlinmt::SimpleScheduler.

◆ processRunHeader()

virtual void marlinmt::IScheduler::processRunHeader ( std::shared_ptr< RunHeader rhdr)
pure virtual

Process a run header.

Parameters
rhdrthe run header to process

Implemented in marlinmt::concurrency::PEPScheduler, and marlinmt::SimpleScheduler.

◆ pushEvent()

virtual void marlinmt::IScheduler::pushEvent ( std::shared_ptr< EventStore event)
pure virtual

Push a new event to the scheduler for processing.

Parameters
eventthe event to push

Implemented in marlinmt::concurrency::PEPScheduler, and marlinmt::SimpleScheduler.


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