OpenRTM-aist  1.2.1
Public Member Functions | Public Attributes | Protected Member Functions | Protected Attributes | List of all members
RTC::OutPortBase Class Referenceabstract

Output base class. More...

#include <OutPortBase.h>

Inheritance diagram for RTC::OutPortBase:
Inheritance graph
[legend]
Collaboration diagram for RTC::OutPortBase:
Collaboration graph
[legend]

Public Member Functions

 OutPortBase (const char *name, const char *data_type)
 Constructor. More...
 
virtual ~OutPortBase (void)
 Destructor. More...
 
void init (coil::Properties &prop)
 Initializing properties. More...
 
virtual bool write ()=0
 Write data. More...
 
coil::Propertiesproperties ()
 Get properties. More...
 
const std::vector< OutPortConnector * > & connectors ()
 Connector list. More...
 
ConnectorInfoList getConnectorProfiles ()
 ConnectorProfile list. More...
 
coil::vstring getConnectorIds ()
 ConnectorId list. More...
 
coil::vstring getConnectorNames ()
 Connector name list. More...
 
OutPortConnectorgetConnectorById (const char *id)
 Getting ConnectorProfile by ID. More...
 
OutPortConnectorgetConnectorByName (const char *name)
 Getting Connector by name. More...
 
bool getConnectorProfileById (const char *id, ConnectorInfo &prof)
 Getting ConnectorProfile by name. More...
 
bool getConnectorProfileByName (const char *name, ConnectorInfo &prof)
 Getting ConnectorProfile by name. More...
 
virtual void activateInterfaces ()
 Activate all Port interfaces. More...
 
virtual void deactivateInterfaces ()
 Deactivate all Port interfaces. More...
 
void addConnectorDataListener (ConnectorDataListenerType listener_type, ConnectorDataListener *listener, bool autoclean=true)
 Adding BufferDataListener type listener. More...
 
void removeConnectorDataListener (ConnectorDataListenerType listener_type, ConnectorDataListener *listener)
 Removing BufferDataListener type listener. More...
 
void addConnectorListener (ConnectorListenerType callback_type, ConnectorListener *listener, bool autoclean=true)
 Adding ConnectorListener type listener. More...
 
void removeConnectorListener (ConnectorListenerType callback_type, ConnectorListener *listener)
 Removing BufferDataListener type listener. More...
 
bool isLittleEndian ()
 return it whether endian setting. More...
 
virtual ReturnCode_t connect (ConnectorProfile &connector_profile) throw (CORBA::SystemException)
 [CORBA interface] Connect the Port More...
 
virtual ConnectorListenersgetListeners ()
 Getting listeners holder. More...
 
- Public Member Functions inherited from RTC::PortBase
 PortBase (const char *name="")
 Constructor. More...
 
virtual ~PortBase (void)
 Destructor. More...
 
virtual PortProfile * get_port_profile () throw (CORBA::SystemException)
 [CORBA interface] Get the PortProfile of the Port More...
 
const PortProfile & getPortProfile () const
 Get the PortProfile of the Port. More...
 
virtual ConnectorProfileList * get_connector_profiles () throw (CORBA::SystemException)
 [CORBA interface] Get the ConnectorProfileList of the Port More...
 
virtual ConnectorProfile * get_connector_profile (const char *connector_id) throw (CORBA::SystemException)
 [CORBA interface] Get the ConnectorProfile More...
 
virtual ReturnCode_t disconnect (const char *connector_id) throw (CORBA::SystemException)
 [CORBA interface] Disconnect the Port More...
 
virtual ReturnCode_t notify_disconnect (const char *connector_id) throw (CORBA::SystemException)
 [CORBA interface] Notify the Ports disconnection More...
 
virtual ReturnCode_t disconnect_all () throw (CORBA::SystemException)
 [CORBA interface] Disconnect the All Ports More...
 
void setName (const char *name)
 Set the name of this Port. More...
 
const char * getName () const
 Get the name of this Port. More...
 
const PortProfile & getProfile () const
 Get the PortProfile of the Port. More...
 
void setPortRef (PortService_ptr port_ref)
 Set the object reference of this Port. More...
 
PortService_ptr getPortRef () const
 Get the object reference of this Port. More...
 
void setOwner (RTObject_ptr owner)
 Set the owner RTObject of the Port. More...
 
void setOnPublishInterfaces (ConnectionCallback *on_publish)
 Setting callback called on publish interfaces. More...
 
void setOnSubscribeInterfaces (ConnectionCallback *on_subscribe)
 Setting callback called on publish interfaces. More...
 
void setOnConnected (ConnectionCallback *on_connected)
 Setting callback called on connection established. More...
 
void setOnUnsubscribeInterfaces (ConnectionCallback *on_subscribe)
 Setting callback called on unsubscribe interfaces. More...
 
void setOnDisconnected (ConnectionCallback *on_disconnected)
 Setting callback called on disconnected. More...
 
void setOnConnectionLost (ConnectionCallback *on_connection_lost)
 Setting callback called on connection lost. More...
 
void setPortConnectListenerHolder (PortConnectListeners *portconnListeners)
 Setting PortConnectListener holder. More...
 
virtual DirectPortBasegetDirectPort ()
 

Public Attributes

DATAPORTSTATUS_ENUM typedef std::vector< OutPortConnector * > ConnectorList
 

Protected Member Functions

void configure ()
 Configureing outport. More...
 
virtual ReturnCode_t publishInterfaces (ConnectorProfile &connector_profile)
 Publish interface information. More...
 
virtual ReturnCode_t subscribeInterfaces (const ConnectorProfile &connector_profile)
 Subscribe to the interface. More...
 
virtual void unsubscribeInterfaces (const ConnectorProfile &connector_profile)
 Disconnect the interface connection. More...
 
void initProviders ()
 OutPort provider initialization. More...
 
void initConsumers ()
 InPort consumer initialization. More...
 
bool checkEndian (const coil::Properties &prop, bool &littleEndian)
 Checking endian flag of serializer. More...
 
OutPortProvidercreateProvider (ConnectorProfile &cprof, coil::Properties &prop)
 OutPort provider creation. More...
 
InPortConsumercreateConsumer (const ConnectorProfile &cprof, coil::Properties &prop)
 InPort consumer creation. More...
 
OutPortConnectorcreateConnector (const ConnectorProfile &cprof, coil::Properties &prop, InPortConsumer *consumer)
 OutPortPushConnector creation. More...
 
OutPortConnectorcreateConnector (const ConnectorProfile &cprof, coil::Properties &prop, OutPortProvider *provider)
 OutPortPullConnector creation. More...
 
virtual ReturnCode_t notify_connect (ConnectorProfile &connector_profile) throw (CORBA::SystemException)
 [CORBA interface] Notify the Ports connection More...
 
InPortBasegetLocalInPort (const ConnectorInfo &profile)
 Getting local peer InPort if available. More...
 
- Protected Member Functions inherited from RTC::PortBase
virtual ReturnCode_t connectNext (ConnectorProfile &connector_profile)
 Call notify_connect() of the next Port. More...
 
virtual ReturnCode_t disconnectNext (ConnectorProfile &connector_profile)
 Call notify_disconnect() of the next Port. More...
 
virtual void setConnectionLimit (int limit_value)
 Set the maximum number of connections. More...
 
virtual ReturnCode_t _publishInterfaces (void)
 Publish interface information. More...
 
bool isEmptyId (const ConnectorProfile &connector_profile) const
 Check whether connector_id of ConnectorProfile is empty. More...
 
const std::string getUUID () const
 Generate the UUID. More...
 
void setUUID (ConnectorProfile &connector_profile) const
 Generate and set the UUID to the ConnectorProfile. More...
 
bool isExistingConnId (const char *id)
 Check whether the given id exists in stored ConnectorProfiles. More...
 
ConnectorProfile findConnProfile (const char *id)
 Find ConnectorProfile with id. More...
 
CORBA::Long findConnProfileIndex (const char *id)
 Find ConnectorProfile with id. More...
 
void updateConnectorProfile (const ConnectorProfile &connector_profile)
 Append or update the ConnectorProfile list. More...
 
bool eraseConnectorProfile (const char *id)
 Delete the ConnectorProfile. More...
 
bool appendInterface (const char *name, const char *type_name, PortInterfacePolarity pol)
 Append an interface to the PortInterfaceProfile. More...
 
bool deleteInterface (const char *name, PortInterfacePolarity pol)
 Delete the interface registration from the PortInterfaceProfile. More...
 
template<class ValueType >
void addProperty (const char *key, ValueType value)
 Add NameValue data to PortProfile's properties. More...
 
void appendProperty (const char *key, const char *value)
 Append NameValue data to PortProfile's properties. More...
 
void updateConnectors ()
 Disconnect ports that doesn't exist. More...
 
bool checkPorts (::RTC::PortServiceList &ports)
 Existence of ports. More...
 
void onNotifyConnect (const char *portname, RTC::ConnectorProfile &profile)
 
void onNotifyDisconnect (const char *portname, RTC::ConnectorProfile &profile)
 
void onUnsubscribeInterfaces (const char *portname, RTC::ConnectorProfile &profile)
 
void onPublishInterfaces (const char *portname, RTC::ConnectorProfile &profile, ReturnCode_t ret)
 
void onConnectNextport (const char *portname, RTC::ConnectorProfile &profile, ReturnCode_t ret)
 
void onSubscribeInterfaces (const char *portname, RTC::ConnectorProfile &profile, ReturnCode_t ret)
 
void onConnected (const char *portname, RTC::ConnectorProfile &profile, ReturnCode_t ret)
 
void onDisconnectNextport (const char *portname, RTC::ConnectorProfile &profile, ReturnCode_t ret)
 
void onDisconnected (const char *portname, RTC::ConnectorProfile &profile, ReturnCode_t ret)
 

Protected Attributes

std::vector< OutPortConnector * > m_connectors
 Connection list. More...
 
coil::vstring m_providerTypes
 Available providers. More...
 
coil::vstring m_consumerTypes
 Available consumers. More...
 
bool m_littleEndian
 Connected Endian. More...
 
ConnectorListeners m_listeners
 ConnectorDataListener listener. More...
 
- Protected Attributes inherited from RTC::PortBase
coil::Properties m_properties
 Properties. More...
 
Logger rtclog
 Logger stream. More...
 
PortProfile m_profile
 PortProfile of the Port. More...
 
RTC::PortService_var m_objref
 Object Reference of the Port. More...
 
coil::Mutex m_profile_mutex
 Mutex of PortProfile. More...
 
coil::Mutex m_connectorsMutex
 
std::string m_ownerInstanceName
 Instance name. More...
 
int m_connectionLimit
 The maximum number of connections. More...
 
ConnectionCallbackm_onPublishInterfaces
 Callback functor objects. More...
 
ConnectionCallbackm_onSubscribeInterfaces
 Callback functor objects. More...
 
ConnectionCallbackm_onConnected
 Callback functor objects. More...
 
ConnectionCallbackm_onUnsubscribeInterfaces
 Callback functor objects. More...
 
ConnectionCallbackm_onDisconnected
 Callback functor objects. More...
 
ConnectionCallbackm_onConnectionLost
 Callback functor objects. More...
 
PortConnectListenersm_portconnListeners
 PortConnectListener holder. More...
 
DirectPortBasem_directport
 

Additional Inherited Members

- Public Types inherited from RTC::DataPortStatus
enum  Enum {
  PORT_OK = 0, PORT_ERROR, BUFFER_ERROR, BUFFER_FULL,
  BUFFER_EMPTY, BUFFER_TIMEOUT, SEND_FULL, SEND_TIMEOUT,
  RECV_EMPTY, RECV_TIMEOUT, INVALID_ARGS, PRECONDITION_NOT_MET,
  CONNECTION_LOST, UNKNOWN_ERROR
}
 DataPortStatus return codes. More...
 
- Static Public Member Functions inherited from RTC::DataPortStatus
static const char * toString (DataPortStatus::Enum status)
 Convert DataPortStatus into the string. More...
 
- Protected Types inherited from RTC::PortBase
typedef coil::Guard< coil::MutexGuard
 

Detailed Description

Output base class.

The base class of OutPort<T> which are implementations of OutPort

Form a kind of Observer pattern with OutPortBase and PublisherBase. attach(), detach(), notify() of OutPortBase and push() of PublisherBase are methods associated with the Observer pattern.

Since
0.2.0

Constructor & Destructor Documentation

RTC::OutPortBase::OutPortBase ( const char *  name,
const char *  data_type 
)

Constructor.

Constructor

Parameters
namePort name
data_typeData type
virtual RTC::OutPortBase::~OutPortBase ( void  )
virtual

Destructor.

Destructor Detach all subscribed Publishers.

Member Function Documentation

virtual void RTC::OutPortBase::activateInterfaces ( )
virtual

Activate all Port interfaces.

This operation activate all interfaces that is registered in the ports.

Implements RTC::PortBase.

void RTC::OutPortBase::addConnectorDataListener ( ConnectorDataListenerType  listener_type,
ConnectorDataListener listener,
bool  autoclean = true 
)

Adding BufferDataListener type listener.

This operation adds certain listeners related to buffer writing and reading events. The following listener types are available.

  • ON_BUFFER_WRITE: At the time of buffer write
  • ON_BUFFER_FULL: At the time of buffer full
  • ON_BUFFER_WRITE_TIMEOUT: At the time of buffer write timeout
  • ON_BUFFER_OVERWRITE: At the time of buffer overwrite
  • ON_BUFFER_READ: At the time of buffer read
  • ON_SEND: At the time of sending to InPort
  • ON_RECEIVED: At the time of finishing sending to InPort
  • ON_SENDER_TIMEOUT: At the time of timeout of OutPort
  • ON_SENDER_ERROR: At the time of error of OutPort
  • ON_RECEIVER_FULL: At the time of bufferfull of InPort
  • ON_RECEIVER_TIMEOUT: At the time of timeout of InPort
  • ON_RECEIVER_ERROR: At the time of error of InPort

Listeners should have the following function operator().

ConnectorDataListener:: operator()(const ConnectorProfile&, const cdrStream&)

The ownership of the given listener object is transferred to this OutPort object in default. The given listener object will be destroied automatically in the OutPort's dtor or if the listener is deleted by removeConnectorDataListener() function. If you want to keep ownership of the listener object, give "false" value to 3rd argument to inhibit automatic destruction.

Parameters
listener_typeA listener type
listenerA pointer to a listener object
autocleanA flag for automatic listener destruction

Referenced by RTC::OutPort< DataType >::OutPort().

void RTC::OutPortBase::addConnectorListener ( ConnectorListenerType  callback_type,
ConnectorListener listener,
bool  autoclean = true 
)

Adding ConnectorListener type listener.

This operation adds certain listeners related to buffer writing and reading events. The following listener types are available.

  • ON_BUFFER_EMPTY: At the time of buffer empty
  • ON_BUFFER_READTIMEOUT: At the time of buffer read timeout

Listeners should have the following function operator().

ConnectorListener::operator()(const ConnectorProfile&)

The ownership of the given listener object is transferred to this OutPort object in default. The given listener object will be destroied automatically in the OutPort's dtor or if the listener is deleted by removeConnectorListener() function. If you want to keep ownership of the listener object, give "false" value to 3rd argument to inhibit automatic destruction.

Parameters
listener_typeA listener type
listenerA pointer to a listener object
autocleanA flag for automatic listener destruction
bool RTC::OutPortBase::checkEndian ( const coil::Properties prop,
bool &  littleEndian 
)
protected

Checking endian flag of serializer.

This operation checks endian flag of data serializer that is specified properties. If valid specification is found, this operation returns true and set argument littleEndian. True means little endian, false means big endian.

Parameters
propProperties
littleEndianEndian Information(true:little,false:big)
Returns
true:"Serializer" key doesn't exist. or "Serializer" key exists and there is a content. false:There is no content though "Serializer" key exists. or ithe content is not "Little. " though "Serializer" key exists, or the content is not "little" or "big" though "Serializer" key exists.
void RTC::OutPortBase::configure ( )
protected

Configureing outport.

This operation configures the outport based on the properties.

virtual ReturnCode_t RTC::OutPortBase::connect ( ConnectorProfile &  connector_profile)
throw (CORBA::SystemException
)
virtual

[CORBA interface] Connect the Port

This operation establishes connection according to the given ConnectionProfile inforamtion. This function is premised on calling from mainly application program or tools.

Parameters
connector_profileThe ConnectorProfile.
Returns
ReturnCode_t The return code of ReturnCode_t type.

Reimplemented from RTC::PortBase.

const std::vector<OutPortConnector*>& RTC::OutPortBase::connectors ( )

Connector list.

This operation returns connector list

Returns
connector list
OutPortConnector* RTC::OutPortBase::createConnector ( const ConnectorProfile &  cprof,
coil::Properties prop,
InPortConsumer consumer 
)
protected
OutPortConnector* RTC::OutPortBase::createConnector ( const ConnectorProfile &  cprof,
coil::Properties prop,
OutPortProvider provider 
)
protected
InPortConsumer* RTC::OutPortBase::createConsumer ( const ConnectorProfile &  cprof,
coil::Properties prop 
)
protected

InPort consumer creation.

OutPortProvider* RTC::OutPortBase::createProvider ( ConnectorProfile &  cprof,
coil::Properties prop 
)
protected

OutPort provider creation.

virtual void RTC::OutPortBase::deactivateInterfaces ( )
virtual

Deactivate all Port interfaces.

This operation deactivate all interfaces that is registered in the ports.

Implements RTC::PortBase.

OutPortConnector* RTC::OutPortBase::getConnectorById ( const char *  id)

Getting ConnectorProfile by ID.

This operation returns Connector specified by ID.

Parameters
idConnector ID
Returns
A pointer to connector
OutPortConnector* RTC::OutPortBase::getConnectorByName ( const char *  name)

Getting Connector by name.

This operation returns Connector specified by name.

Parameters
idConnector ID
Returns
A pointer to connector
coil::vstring RTC::OutPortBase::getConnectorIds ( )

ConnectorId list.

This operation returns ConnectorId list

Returns
connector list
coil::vstring RTC::OutPortBase::getConnectorNames ( )

Connector name list.

This operation returns Connector name list

Returns
connector name list
bool RTC::OutPortBase::getConnectorProfileById ( const char *  id,
ConnectorInfo prof 
)

Getting ConnectorProfile by name.

This operation returns ConnectorProfile specified by name

Parameters
idConnector ID
profConnectorProfile
Returns
false specified ID does not exist
bool RTC::OutPortBase::getConnectorProfileByName ( const char *  name,
ConnectorInfo prof 
)

Getting ConnectorProfile by name.

This operation returns ConnectorProfile specified by name

Parameters
idConnector ID
profConnectorProfile
Returns
false specified name does not exist
ConnectorInfoList RTC::OutPortBase::getConnectorProfiles ( )

ConnectorProfile list.

This operation returns ConnectorProfile list

Returns
connector list
virtual ConnectorListeners& RTC::OutPortBase::getListeners ( )
virtual

Getting listeners holder.

This operation returns listeners holder.

Returns
ConnectorListeners
InPortBase* RTC::OutPortBase::getLocalInPort ( const ConnectorInfo profile)
protected

Getting local peer InPort if available.

void RTC::OutPortBase::init ( coil::Properties prop)

Initializing properties.

This operation initializes outport's properties

Parameters
propProperty for setting ports
void RTC::OutPortBase::initConsumers ( )
protected

InPort consumer initialization.

void RTC::OutPortBase::initProviders ( )
protected

OutPort provider initialization.

bool RTC::OutPortBase::isLittleEndian ( )

return it whether endian setting.

Returns
Return true in the case of "little", false in "big" than it.
virtual ReturnCode_t RTC::OutPortBase::notify_connect ( ConnectorProfile &  connector_profile)
throw (CORBA::SystemException
)
protectedvirtual

[CORBA interface] Notify the Ports connection

This operation is usually called from other ports' connect() or notify_connect() operations when connection between ports is established. This function is not premised on calling from other functions or application programs.

According to the template method pattern, the notify_connect() calls "publishInterfaces()" and "subsctiveInterfaces()" functions, which are premised on implementing in the subclasses. The processing sequence is as follows.

According to the order of port's references stored in the ConnectorProfile::ports, publishing interface information to all the ports and subscription interface information from all the ports is performed by "notify_connect()"s. This cascaded call never aborts in the halfway operations, and calling sequence shall be completed for all the ports.

Precondition
notify_connect() calls notify_connect() for the port's reference that is stored in next of this port's reference in the sequence of the ConnectorProfile::ports. Therefore the reference of this port shall be stored in the ConnectorProfile::ports. If this port's reference is not stored in the sequence, BAD_PARAMETER error will be returned, except the return code is overwritten by other operations.
UUID shall be set to ConnectorProfile::connector_id as a unique identifier when this operation is called. Usually, connector_id is given by a connect() function and, the behavior is undefined in the case of a null character.
Postcondition
ConnectorProfile::name, ConnectorProfile::connector_id, ConnectorProfile::ports are invariant, and they are never rewritten by notify_connect() operations.
In order to transfer interface information to other ports, interface property information is stored into the ConnectorProfile::properties.
At the end of notify_connect() operation for the first port stored in the ConnectorProfile::ports sequence, the related ports' notify_connect() invocations complete. Even if errors are raised at the halfway of publishInterfaces(), connectNext(), subscribeInterfaces() and storing process of ConnectorProfile, error codes are saved and the first error is returned.
Parameters
connector_profileThe ConnectorProfile.
Returns
ReturnCode_t The return code of ReturnCode_t type.

Reimplemented from RTC::PortBase.

coil::Properties& RTC::OutPortBase::properties ( )

Get properties.

Getting properties of this OutPort

Returns
OutPort's properties
virtual ReturnCode_t RTC::OutPortBase::publishInterfaces ( ConnectorProfile &  connector_profile)
protectedvirtual

Publish interface information.

This operation is pure virutal function that would be called at the beginning of the notify_connect() process sequence. In the notify_connect(), the following methods would be called in order.

This operation should create the new connection for the new connector_id, and should update the connection for the existing connection_id.

Parameters
connector_profileThe connection profile information
Returns
The return code of ReturnCode_t type.

Implements RTC::PortBase.

void RTC::OutPortBase::removeConnectorDataListener ( ConnectorDataListenerType  listener_type,
ConnectorDataListener listener 
)

Removing BufferDataListener type listener.

This operation removes a specified listener.

Parameters
listener_typeA listener type
listenerA pointer to a listener object
void RTC::OutPortBase::removeConnectorListener ( ConnectorListenerType  callback_type,
ConnectorListener listener 
)

Removing BufferDataListener type listener.

This operation removes a specified listener.

Parameters
listener_typeA listener type
listenerA pointer to a listener object
virtual ReturnCode_t RTC::OutPortBase::subscribeInterfaces ( const ConnectorProfile &  connector_profile)
protectedvirtual

Subscribe to the interface.

This operation is pure virutal function that would be called at the middle of the notify_connect() process sequence. In the notify_connect(), the following methods would be called in order.

Parameters
connector_profileThe connection profile information
Returns
The return code of ReturnCode_t type.

Implements RTC::PortBase.

virtual void RTC::OutPortBase::unsubscribeInterfaces ( const ConnectorProfile &  connector_profile)
protectedvirtual

Disconnect the interface connection.

This operation is pure virutal function that would be called at the end of the notify_disconnect() process sequence. In the notify_disconnect(), the following methods would be called.

Parameters
connector_profileThe profile information associated with the connection

Implements RTC::PortBase.

virtual bool RTC::OutPortBase::write ( )
pure virtual

Write data.

Write data to the port. Write the value, which was set to the bound variable, to the port.

Returns
Writing result (Successful:true, Failed:false)

Implemented in RTC::OutPort< DataType >.

Member Data Documentation

DATAPORTSTATUS_ENUM typedef std::vector<OutPortConnector*> RTC::OutPortBase::ConnectorList
std::vector<OutPortConnector*> RTC::OutPortBase::m_connectors
protected

Connection list.

Referenced by RTC::OutPort< DataType >::write().

coil::vstring RTC::OutPortBase::m_consumerTypes
protected

Available consumers.

ConnectorListeners RTC::OutPortBase::m_listeners
protected
bool RTC::OutPortBase::m_littleEndian
protected

Connected Endian.

coil::vstring RTC::OutPortBase::m_providerTypes
protected

Available providers.


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