Hedgehog
3.1.0
A library to generate hybrid pipeline workflow systems
|
Input management abstraction for the task. More...
#include "task_inputs_management_abstraction.h"
Public Types | |
using | inputs_t = std::tuple< Inputs... > |
Accessor to the input types. | |
Public Member Functions | |
template<class NodeType > | |
TaskInputsManagementAbstraction (NodeType *const nodeTask, TaskNodeAbstraction *const coreTask) | |
Constructor using a node task and its core. | |
template<hh::tool::ConcreteMultiReceiverImplementation< Inputs... > ConcreteMultiReceivers, hh::tool::ConcreteMultiExecuteImplementation< Inputs... > ConcreteMultiExecutes> | |
TaskInputsManagementAbstraction (TaskNodeAbstraction *const coreTask, std::shared_ptr< implementor::ImplementorSlot > concreteSlot, std::shared_ptr< ConcreteMultiReceivers > concreteMultiReceivers, std::shared_ptr< ConcreteMultiExecutes > concreteMultiExecutes) | |
Constructor using a node and the concrete implementor. | |
~TaskInputsManagementAbstraction () override=default | |
Default destructor. | |
bool | receiversEmpty () const |
Test if the receivers are empty for the task. | |
![]() | |
SlotAbstraction (std::shared_ptr< implementor::ImplementorSlot > concreteSlot) | |
Constructor using a concrete slot implementation. | |
virtual | ~SlotAbstraction ()=default |
Default destructor. | |
std::set< SlotAbstraction * > const & | slots () const |
Const accessor to slots. | |
std::set< SlotAbstraction * > & | slots () |
Accessor to slots. | |
std::set< NotifierAbstraction * > const & | connectedNotifiers () const |
Accessor to the NotifierAbstraction attached to this slot, protected with mutex. | |
void | addNotifier (NotifierAbstraction *const notifier) |
Add a NotifierAbstraction to this slot. | |
void | removeNotifier (NotifierAbstraction *const notifier) |
Remove a NotifierAbstraction to this slot. | |
virtual void | wakeUp ()=0 |
Wake up mechanism, called to notify the std::condition_variable. | |
bool | hasNotifierConnected () const |
Test if there is at least one notifier connected. | |
void | lockSlotMutex () |
Lock mutex. | |
void | unlockSlotMutex () |
Unlock mutex. | |
![]() | |
ReceiverAbstraction (std::shared_ptr< implementor::ImplementorReceiver< Inputs > > concreteReceiver, std::shared_ptr< std::mutex > slotMutex) | |
Constructor using a concrete implementation of a receiver implementor, and the mutex from the slot. | |
virtual | ~ReceiverAbstraction ()=default |
Default destructor. | |
std::set< ReceiverAbstraction * > const & | receivers () const |
Const accessor to receivers. | |
std::set< ReceiverAbstraction * > & | receivers () |
Accessor to receivers. | |
std::set< SenderAbstraction< Inputs > * > const & | connectedSenders () const |
Accessor to the senders attached to this receiver. | |
void | receive (std::shared_ptr< Inputs > const inputData) |
Receive a piece of data. | |
std::shared_ptr< Inputs > | getInputData () |
Get an input data from the concrete receiver implementation. | |
size_t | numberElementsReceived () const |
Accessor to the current number of input data received and waiting to be processed. | |
size_t | maxNumberElementsReceived () const |
Accessor to the maximum number of input data received and waiting to be processed. | |
bool | empty () const |
Test if the receiver is empty. | |
void | addSender (SenderAbstraction< Inputs > *const sender) |
Add a SenderAbstraction to the concrete receiver implementation. | |
void | removeSender (SenderAbstraction< Inputs > *const sender) |
Remove a SenderAbstraction to the concrete receiver implementation. | |
void | printEdgeInformation (Printer *printer) |
Add to the printer the edge information. | |
![]() | |
ExecuteAbstraction (std::shared_ptr< implementor::ImplementorExecute< Inputs > > concreteExecute) | |
Constructor using a user-defined execution. | |
virtual | ~ExecuteAbstraction ()=default |
Default destructor. | |
void | callExecute (std::shared_ptr< Inputs > data) |
Interface for calling user-defined execution. | |
Protected Member Functions | |
size_t | totalNumberElementsReceived () const |
Accessor to the total number of elements received for all input types. | |
void | operateReceivers () |
Access all the task receivers to process an element. | |
void | callAllExecuteWithNullptr () |
Call for all types the user-defined execute method with nullptr as data. | |
void | wakeUp () final |
Wake up implementation (notify one node waiting on the condition variable) | |
void | copyInnerStructure (TaskInputsManagementAbstraction< Inputs... > *copyableCore) |
Copy the task core inner structure to this. | |
void | printEdgesInformation (Printer *printer) |
Add edge information to the printer. | |
![]() | |
std::shared_ptr< std::mutex > const & | mutex () const |
Protected accessor to mutex. | |
std::shared_ptr< std::condition_variable > const & | slotConditionVariable () const |
Protected accessor to condition variable. | |
void | copyInnerStructure (SlotAbstraction *copyableCore) |
Copy the inner structure of copyableCore into this. | |
![]() | |
void | copyInnerStructure (ReceiverAbstraction< Inputs > *copyableCore) |
Copy inner structure of the receiver to this one. | |
Private Member Functions | |
template<tool::ContainsConcept< Inputs... > InputDataType> | |
void | operateReceiver () |
Access the ReceiverAbstraction of the type InputDataType to process an element. | |
Private Attributes | |
TaskNodeAbstraction *const | coreTask_ = nullptr |
Accessor to the core task. | |
Input management abstraction for the task.
Inputs | Types of input data |
Definition at line 46 of file task_inputs_management_abstraction.h.
using hh::core::abstraction::TaskInputsManagementAbstraction< Inputs >::inputs_t = std::tuple<Inputs...> |
Accessor to the input types.
Definition at line 53 of file task_inputs_management_abstraction.h.
|
inlineexplicit |
Constructor using a node task and its core.
NodeType | Type of the node |
nodeTask | Node instance |
coreTask | Core node instance |
Definition at line 60 of file task_inputs_management_abstraction.h.
|
inlineexplicit |
Constructor using a node and the concrete implementor.
ConcreteMultiReceivers | Concrete implementation of multi receivers abstraction |
ConcreteMultiExecutes | Concrete implementation of execute abstraction |
coreTask | Core task instance |
concreteSlot | Concrete slot implementation |
concreteMultiReceivers | Concrete multi receivers implementation |
concreteMultiExecutes | Concrete multi executes implementation |
Definition at line 80 of file task_inputs_management_abstraction.h.
|
overridedefault |
Default destructor.
|
inlineprotected |
Call for all types the user-defined execute method with nullptr as data.
Definition at line 111 of file task_inputs_management_abstraction.h.
|
inlineprotected |
Copy the task core inner structure to this.
copyableCore | Task core to copy from |
Definition at line 118 of file task_inputs_management_abstraction.h.
|
inlineprivate |
Access the ReceiverAbstraction of the type InputDataType to process an element.
InputDataType |
Definition at line 133 of file task_inputs_management_abstraction.h.
|
inlineprotected |
Access all the task receivers to process an element.
Definition at line 108 of file task_inputs_management_abstraction.h.
|
inlineprotected |
Add edge information to the printer.
printer | Printer visitor gathering edge information |
Definition at line 125 of file task_inputs_management_abstraction.h.
|
inline |
Test if the receivers are empty for the task.
Definition at line 97 of file task_inputs_management_abstraction.h.
|
inlineprotected |
Accessor to the total number of elements received for all input types.
Definition at line 103 of file task_inputs_management_abstraction.h.
|
inlinefinalprotectedvirtual |
Wake up implementation (notify one node waiting on the condition variable)
Implements hh::core::abstraction::SlotAbstraction.
Definition at line 114 of file task_inputs_management_abstraction.h.
|
private |
Accessor to the core task.
Definition at line 51 of file task_inputs_management_abstraction.h.