OpenWalnut  1.5.0dev
Public Types | Public Member Functions | Static Public Member Functions | Private Attributes | List of all members
WModuleInputData< T > Class Template Reference

Class offering an instantiate-able data connection between modules. More...

#include <WModuleInputData.h>

+ Inheritance diagram for WModuleInputData< T >:
+ Collaboration diagram for WModuleInputData< T >:

Public Types

typedef std::shared_ptr< WModuleInputData< T > > PtrType
 Pointer to this. More...
 
typedef std::shared_ptr< WModuleInputData< T > > SPtr
 Pointer to this. More...
 
typedef std::shared_ptr< const WModuleInputData< T > > ConstSPtr
 Pointer to this. More...
 
typedef WModuleInputData< T > & RefType
 Reference to this type. More...
 
typedef WModuleInputData< T > Type
 Type of the connector. More...
 
typedef T TransferType
 Typedef to the contained transferable. More...
 
- Public Types inherited from WModuleConnector
typedef std::shared_ptr< WModuleConnectorSPtr
 Shared pointer to this class. More...
 
typedef std::shared_ptr< const WModuleConnectorConstSPtr
 Const shared pointer to this class. More...
 

Public Member Functions

 WModuleInputData (std::shared_ptr< WModule > module, std::string name="", std::string description="")
 Constructor. More...
 
virtual ~WModuleInputData ()
 Destructor. More...
 
virtual void disconnect (std::shared_ptr< WModuleConnector > con, bool removeFromOwnList=true)
 Disconnects this connector if connected. More...
 
const std::shared_ptr< T > getData (bool reset=true)
 Gives the currently set data and resets the update flag. More...
 
virtual bool connectable (std::shared_ptr< WModuleConnector > con)
 Checks whether the specified connector is an input connector and compatible with T. More...
 
- Public Member Functions inherited from WModuleInputConnector
 WModuleInputConnector (std::shared_ptr< WModule > module, std::string name="", std::string description="")
 Constructor. More...
 
virtual ~WModuleInputConnector ()
 Destructor. More...
 
virtual bool lazyConnectable (std::shared_ptr< WModuleConnector > con)
 Checks whether the specified connector is connectable to this one, but ignores compatibility the type to be transferred. More...
 
boost::signals2::connection subscribeSignal (MODULE_CONNECTOR_SIGNAL signal, t_GenericSignalHandlerType notifier)
 Connects (subscribes) a specified notify function with a signal this module instance is offering. More...
 
virtual bool isInputConnector () const
 Returns true if this instance is an WModuleInputConnector. More...
 
virtual bool isOutputConnector () const
 Returns true if this instance is an WModuleOutputConnector. More...
 
virtual bool updated ()
 Denotes whether the connected output was updated. More...
 
virtual bool handledUpdate ()
 Resets the updated-flag. More...
 
- Public Member Functions inherited from WModuleConnector
 WModuleConnector (std::shared_ptr< WModule > module, std::string name="", std::string description="")
 Constructor. More...
 
virtual ~WModuleConnector ()
 Destructor. More...
 
std::shared_ptr< WModulegetModule () const
 Returns the module which owns this connector. More...
 
virtual void disconnectAll ()
 Disconnects ALL connected connectors. More...
 
virtual void connect (std::shared_ptr< WModuleConnector > con, bool force=false)
 Connects this Module Connector with another one. More...
 
bool isConnectedTo (std::shared_ptr< WModuleConnector > con)
 Checks whether this connector is connected to the given one. More...
 
unsigned int isConnected ()
 Gets the count of connections currently established. More...
 
const std::string getDescription () const
 Gives information about this connection. More...
 
void setDescription (std::string desc)
 Sets the connector's description. More...
 
const std::string getName () const
 Gives name of connection. More...
 
const std::string getCanonicalName () const
 Gives canonical name of connection. More...
 
void setName (std::string name)
 Sets the connector's name. More...
 
WCombinerTypes::WOneToOneCombiners getPossibleDisconnections ()
 Returns a list of possible disconnections for this connector. More...
 
std::shared_ptr< WModuleInputConnectortoInputConnector ()
 Tries to convert this instance to an input connector. More...
 
std::shared_ptr< WModuleOutputConnectortoOutputConnector ()
 Tries to convert this instance to an output connector. More...
 
std::shared_ptr< WConditiongetDataChangedCondition ()
 Gets the condition variable that gets fired whenever new data has been sent. More...
 

Static Public Member Functions

static PtrType create (std::shared_ptr< WModule > module, std::string name="", std::string description="")
 Convenience method to create a new instance of this in data connector with proper type. More...
 
static PtrType createAndAdd (std::shared_ptr< WModule > module, std::string name="", std::string description="")
 Convenience method to create a new instance of this in data connector with proper type and add it to the list of connectors of the specified module. More...
 

Private Attributes

bool m_disconnecting
 If true, the returned data will be NULL. More...
 

Additional Inherited Members

- Protected Member Functions inherited from WModuleInputConnector
virtual void connectSignals (std::shared_ptr< WModuleConnector > con)
 Connect additional signals. More...
 
virtual void disconnectSignals (std::shared_ptr< WModuleConnector > con)
 Disconnect all signals subscribed by this connector from "con". More...
 
virtual void notifyDataChange (std::shared_ptr< WModuleConnector > input, std::shared_ptr< WModuleConnector > output)
 Gets called when the data on this input connector changed. More...
 
virtual void notifyConnectionEstablished (std::shared_ptr< WModuleConnector > here, std::shared_ptr< WModuleConnector > there)
 Gets called whenever a connector gets connected to the specified input. More...
 
virtual void setUpdated ()
 Sets the update flag (use updated() to query it)to true. More...
 
- Protected Member Functions inherited from WModuleConnector
virtual const t_GenericSignalHandlerType getSignalHandler (MODULE_CONNECTOR_SIGNAL signal)
 Gives the signal handler function responsible for a given signal. More...
 
virtual void notifyConnectionClosed (std::shared_ptr< WModuleConnector > here, std::shared_ptr< WModuleConnector > there)
 Gets called whenever a connection between a remote and local connector gets closed. More...
 
- Protected Attributes inherited from WModuleConnector
std::set< std::shared_ptr< WModuleConnector > > m_connected
 List of connectors connected to this connector. More...
 
std::shared_mutex m_connectionListLock
 Lock for avoiding concurrent write to m_Connected (multiple reader, single writer lock). More...
 
std::weak_ptr< WModulem_module
 The Module this connector belongs to. More...
 
std::string m_moduleName
 The name of the module owning this connector. More...
 
t_GenericSignalType signal_ConnectionEstablished
 Signal emitted whenever connection has been established. More...
 
t_GenericSignalType signal_ConnectionClosed
 Signal emitted whenever connection has been closed. More...
 
std::shared_ptr< WConditionm_dataChangedCondition
 Condition fired whenever data changes. More...
 

Detailed Description

template<typename T>
class WModuleInputData< T >

Class offering an instantiate-able data connection between modules.

Due to is template style it is possible to bind nearly arbitrary data.

Definition at line 46 of file WModuleInputData.h.

Member Typedef Documentation

◆ ConstSPtr

template<typename T >
typedef std::shared_ptr< const WModuleInputData< T > > WModuleInputData< T >::ConstSPtr

Pointer to this.

For convenience.

Definition at line 62 of file WModuleInputData.h.

◆ PtrType

template<typename T >
typedef std::shared_ptr< WModuleInputData< T > > WModuleInputData< T >::PtrType

Pointer to this.

For convenience.

Definition at line 52 of file WModuleInputData.h.

◆ RefType

template<typename T >
typedef WModuleInputData< T >& WModuleInputData< T >::RefType

Reference to this type.

Definition at line 67 of file WModuleInputData.h.

◆ SPtr

template<typename T >
typedef std::shared_ptr< WModuleInputData< T > > WModuleInputData< T >::SPtr

Pointer to this.

For convenience.

Definition at line 57 of file WModuleInputData.h.

◆ TransferType

template<typename T >
typedef T WModuleInputData< T >::TransferType

Typedef to the contained transferable.

Definition at line 77 of file WModuleInputData.h.

◆ Type

template<typename T >
typedef WModuleInputData< T > WModuleInputData< T >::Type

Type of the connector.

Definition at line 72 of file WModuleInputData.h.

Constructor & Destructor Documentation

◆ WModuleInputData()

template<typename T >
WModuleInputData< T >::WModuleInputData ( std::shared_ptr< WModule module,
std::string  name = "",
std::string  description = "" 
)
inline

Constructor.

Parameters
modulethe module which is owner of this connector.
nameThe name of this connector.
descriptionShort description of this connector.

Definition at line 109 of file WModuleInputData.h.

◆ ~WModuleInputData()

template<typename T >
virtual WModuleInputData< T >::~WModuleInputData ( )
inlinevirtual

Destructor.

Definition at line 118 of file WModuleInputData.h.

Member Function Documentation

◆ connectable()

template<typename T >
virtual bool WModuleInputData< T >::connectable ( std::shared_ptr< WModuleConnector con)
inlinevirtual

Checks whether the specified connector is an input connector and compatible with T.

Parameters
conthe connector to check against.
Returns
true if compatible.

Reimplemented from WModuleInputConnector.

Definition at line 173 of file WModuleInputData.h.

References WModuleInputConnector::connectable().

+ Here is the call graph for this function:

◆ create()

template<typename T >
WModuleInputData< T >::PtrType WModuleInputData< T >::create ( std::shared_ptr< WModule module,
std::string  name = "",
std::string  description = "" 
)
static

Convenience method to create a new instance of this in data connector with proper type.

Parameters
modulethe module owning this instance
namethe name of this connector.
descriptionthe description of this connector.
Returns
the pointer to the created connector.

Definition at line 209 of file WModuleInputData.h.

◆ createAndAdd()

template<typename T >
WModuleInputData< T >::PtrType WModuleInputData< T >::createAndAdd ( std::shared_ptr< WModule module,
std::string  name = "",
std::string  description = "" 
)
static

Convenience method to create a new instance of this in data connector with proper type and add it to the list of connectors of the specified module.

Parameters
modulethe module owning this instance
namethe name of this connector.
descriptionthe description of this connector.
Returns
the pointer to the created connector.

Definition at line 218 of file WModuleInputData.h.

Referenced by WMButterfly::connectors(), WMColormapper::connectors(), WMWriteNIfTI::connectors(), WMDiffTensorScalars::connectors(), WMDirectVolumeRendering::connectors(), WMEigenSystem::connectors(), WMFiberFilterIndex::connectors(), WMFiberFilterROI::connectors(), WMFiberResampling::connectors(), WMFilterProtonData::connectors(), WMPartition2Mesh::connectors(), WMImageSpaceLIC::connectors(), WMImageSpaceTensorLIC::connectors(), WMIsosurfaceRaytracer::connectors(), WMMergeComponentsToVector::connectors(), WMMergePoints::connectors(), WMPickingDVR::connectors(), WMPickingDVREvaluation::connectors(), WMPointConnector::connectors(), WMPointRenderer::connectors(), WMProjectionsAsContext::connectors(), WMScalarOperator::connectors(), WMSpatialDerivative::connectors(), WMSurfaceIllustrator::connectors(), WMTemplate::connectors(), WMTransferFunctionColorBar::connectors(), WMTriangleMeshRenderer::connectors(), WMVectorAlign::connectors(), WMVectorNormalize::connectors(), WMVectorOperator::connectors(), WMVectorScale::connectors(), WMVoxelizer::connectors(), WMWriteAmiraMesh::connectors(), WMWriteDendrogram::connectors(), WMWriteCSV::connectors(), and WMWriteTracts::connectors().

+ Here is the caller graph for this function:

◆ disconnect()

template<typename T >
void WModuleInputData< T >::disconnect ( std::shared_ptr< WModuleConnector con,
bool  removeFromOwnList = true 
)
virtual

Disconnects this connector if connected.

If it is not connected: nothing happens.

Parameters
conthe connector to disconnect.
removeFromOwnListif true the specified connection is also removed from the own connection list. If false it won't.

Reimplemented from WModuleConnector.

Definition at line 201 of file WModuleInputData.h.

References WModuleConnector::disconnect().

+ Here is the call graph for this function:

◆ getData()

template<typename T >
const std::shared_ptr< T > WModuleInputData< T >::getData ( bool  reset = true)
inline

Gives the currently set data and resets the update flag.

Parameters
resetreset the flag of updated() if true (default).
Returns
the data currently set. NULL if no data has been sent yet or the connector is unconnected.

Definition at line 137 of file WModuleInputData.h.

References WModuleInputConnector::handledUpdate(), WModuleConnector::m_connected, WModuleConnector::m_connectionListLock, and WModuleInputData< T >::m_disconnecting.

Referenced by WMTransferFunction1D::moduleMain(), and WMWriteTransferFunction::moduleMain().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

Member Data Documentation

◆ m_disconnecting

template<typename T >
bool WModuleInputData< T >::m_disconnecting
private

If true, the returned data will be NULL.

Needed because disconnection process is based on multiple steps.

Definition at line 197 of file WModuleInputData.h.

Referenced by WModuleInputData< T >::getData().


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