#include <PortBase.h>
Inheritance diagram for RTC::PortBase:

| Public Member Functions | |
| PortBase (const char *name="") | |
| Constructor. | |
| virtual | ~PortBase () | 
| Destructor. | |
| virtual PortProfile * | get_port_profile () | 
| [CORBA interface] Get the PortProfile of the Port | |
| const PortProfile & | getPortProfile () const | 
| virtual ConnectorProfileList * | get_connector_profiles () | 
| [CORBA interface] Get the ConnectorProfileList of the Port | |
| virtual ConnectorProfile * | get_connector_profile (const char *connector_id) | 
| [CORBA interface] Get the ConnectorProfile | |
| virtual ReturnCode_t | connect (ConnectorProfile &connector_profile) | 
| [CORBA interface] Connect the Port | |
| virtual ReturnCode_t | notify_connect (ConnectorProfile &connector_profile) | 
| [CORBA interface] Notify the Ports connection | |
| virtual ReturnCode_t | disconnect (const char *connector_id) | 
| [CORBA interface] Connect the Port | |
| virtual ReturnCode_t | notify_disconnect (const char *connector_id) | 
| [CORBA interface] Notify the Ports disconnection | |
| virtual ReturnCode_t | disconnect_all () | 
| [CORBA interface] Connect the Port | |
| void | setName (const char *name) | 
| Set the name of this Port. | |
| const PortProfile & | getProfile () const | 
| Get the PortProfile of the Port. | |
| void | setPortRef (Port_ptr port_ref) | 
| Set the object reference of this Port. | |
| Port_ptr | getPortRef () | 
| Get the object reference of this Port. | |
| void | setOwner (RTObject_ptr owner) | 
| Set the owner RTObject of the Port. | |
| Protected Types | |
| typedef ACE_Guard< ACE_Recursive_Thread_Mutex > | Guard | 
| Protected Member Functions | |
| virtual ReturnCode_t | publishInterfaces (ConnectorProfile &connector_profile)=0 | 
| Publish interface information. | |
| virtual ReturnCode_t | connectNext (ConnectorProfile &connector_profile) | 
| Call notify_connect() of the next Port. | |
| virtual ReturnCode_t | disconnectNext (ConnectorProfile &connector_profile) | 
| Call notify_disconnect() of the next Port. | |
| virtual ReturnCode_t | subscribeInterfaces (const ConnectorProfile &connector_profile)=0 | 
| Publish interface information. | |
| virtual void | unsubscribeInterfaces (const ConnectorProfile &connector_profile)=0 | 
| Disconnect interface connection. | |
| bool | isEmptyId (const ConnectorProfile &connector_profile) const | 
| Whether connector_id of ConnectorProfile is empty. | |
| const std::string | getUUID () const | 
| Get the UUID. | |
| void | setUUID (ConnectorProfile &connector_profile) const | 
| Create and set the UUID to the ConnectorProfile. | |
| bool | isExistingConnId (const char *id) | 
| Whether the given id exists in stored ConnectorProfiles. | |
| ConnectorProfile | findConnProfile (const char *id) | 
| Find ConnectorProfile with id. | |
| CORBA::Long | findConnProfileIndex (const char *id) | 
| Find ConnectorProfile with id. | |
| void | updateConnectorProfile (const ConnectorProfile &connector_profile) | 
| Append or update the ConnectorProfile list. | |
| bool | eraseConnectorProfile (const char *id) | 
| Delete the ConnectorProfile. | |
| bool | appendInterface (const char *name, const char *type_name, PortInterfacePolarity pol) | 
| Append an interface to the PortInterfaceProfile. | |
| bool | deleteInterface (const char *name, PortInterfacePolarity pol) | 
| Delete an interface from the PortInterfaceProfile. | |
| template<class ValueType> | |
| void | addProperty (const char *key, ValueType value) | 
| Add NameValue data to PortProfile's properties. | |
| Protected Attributes | |
| PortProfile | m_profile | 
| PortProfile of the Port. | |
| RTC::Port_var | m_objref | 
| ACE_Recursive_Thread_Mutex | m_profile_mutex | 
| Classes | |
| struct | connect_func | 
| A functor to connect Ports.  More... | |
| struct | disconnect_all_func | 
| A functor to disconnect all Ports.  More... | |
| struct | disconnect_func | 
| A functor to disconnect Ports.  More... | |
| struct | find_conn_id | 
| A functor to find a ConnectorProfile named id.  More... | |
| struct | find_interface | 
| A functor to find interface from name and polarity.  More... | |
| struct | find_port_ref | 
| A functor to find the object reference that is identical port_ref.  More... | |
| struct | if_name | 
| A functor to find a PortInterfaceProfile named instance_name.  More... | |
| 
 | 
| 
 | 
| 
 | 
| Constructor. The constructor of the ProtBase class is given the name of this Port and initialized. At the same time, the PortBase activates itself as CORBA object and stores its object reference to the PortProfile's port_ref member. 
 
 | 
| 
 | 
| Destructor. 
 | 
| 
 | ||||||||||||||||
| Add NameValue data to PortProfile's properties. 
 
 | 
| 
 | ||||||||||||||||
| Append an interface to the PortInterfaceProfile. This operation appends interface information to the PortInterfaceProfile that is owned by the Port. The given interfaces information only updates PortInterfaceProfile of PortProfile that is obtained through get_port_profile(). In order to provide and require interfaces, proper functions (for example publishInterface(), subscribeInterface() and so on) should be overridden in subclasses, and these functions provide concrete interface connection and disconnection functionality. The interface (instance) name have to be unique in the Port. If the given interface name is identical with stored interface name, this function returns false. 
 
 
 | 
| 
 | 
| [CORBA interface] Connect the Port This operation establishes connection according to the given ConnectionProfile inforamtion. Application programs, which is going to establish the connection among Ports owned by RT-Components, have to set valid values to the ConnectorProfile and give it to the argument of connect() operation. name, ports, (properties) members of ConnectorProfile should be set valid values before giving to the argument of connect() operation. 
 
 
 | 
| 
 | 
| Call notify_connect() of the next Port. This operation calls the notify_connect() of the next Port's that stored in ConnectorProfile's port_ref sequence. 
 
 
 | 
| 
 | ||||||||||||
| Delete an interface from the PortInterfaceProfile. This operation deletes interface information from the PortInterfaceProfile that is owned by the Port. 
 
 
 | 
| 
 | 
| [CORBA interface] Connect the Port This operation destroys connection between this port and the peer port according to given id that is given when the connection established. 
 
 
 | 
| 
 | 
| [CORBA interface] Connect the Port This operation destroys all connection channels owned by the Port. 
 
 | 
| 
 | 
| Call notify_disconnect() of the next Port. This operation calls the notify_disconnect() of the next Port's that stored in ConnectorProfile's port_ref sequence. 
 
 
 | 
| 
 | 
| Delete the ConnectorProfile. This operation deletes a ConnectorProfile specified by id from ConnectorProfileList owned by PortProfile of this Port. 
 
 | 
| 
 | 
| Find ConnectorProfile with id. This operation returns ConnectorProfile with the given id from Port's ConnectorProfiles' list. If the ConnectorProfile with connector id that is identical with the given id does not exist, empty ConnectorProfile is returned. 
 
 
 | 
| 
 | 
| Find ConnectorProfile with id. This operation returns ConnectorProfile with the given id from Port's ConnectorProfiles' list. If the ConnectorProfile with connector id that is identical with the given id does not exist, empty ConnectorProfile is returned. 
 
 
 | 
| 
 | 
| [CORBA interface] Get the ConnectorProfile This operation returns the ConnectorProfiles specified connector_id. 
 
 
 | 
| 
 | 
| [CORBA interface] Get the ConnectorProfileList of the Port This operation returns a list of the ConnectorProfiles of the Port. ConnectorProfile includes the connection information that describes relation between (among) Ports, and Ports exchange the ConnectionProfile on connection process and hold the same information in each Port. ConnectionProfile has the following members, 
 
 
 
 | 
| 
 | 
| [CORBA interface] Get the PortProfile of the Port This operation returns the PortProfile of the Port. PortProfile struct has the following members, 
 
 
 
 | 
| 
 | 
| 
 | 
| 
 | 
| Get the object reference of this Port. This operation returns the object reference that is stored in the Port's PortProfile. 
 
 | 
| 
 | 
| Get the PortProfile of the Port. This operation returns const reference of the PortProfile. 
 
 | 
| 
 | 
| Get the UUID. This operation generates UUID. 
 
 | 
| 
 | 
| Whether connector_id of ConnectorProfile is empty. 
 
 | 
| 
 | 
| Whether the given id exists in stored ConnectorProfiles. This operation returns boolean whether the given id exists in the Port's ConnectorProfiles. 
 
 | 
| 
 | 
| [CORBA interface] Notify the Ports connection This operation is invoked between Ports internally when the connection is established. 
 
 
 | 
| 
 | 
| [CORBA interface] Notify the Ports disconnection This operation is invoked between Ports internally when the connection is destroied. 
 
 
 | 
| 
 | 
| Publish interface information. This operation is pure virutal method 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. 
 
In the concrete Port, this method should be overridden. This method processes the given ConnectorProfile argument and if the given parameter is invalid, it would return error code of ReturnCode_t. Usually, publishInterfaces() method should set interfaces information owned by this Port, and publish it to the other Ports.  
 
 
 Implemented in RTC::CorbaPort, RTC::DataInPort, and RTC::DataOutPort. | 
| 
 | 
| Set the name of this Port. This operation sets the name of this Port. The given Port's name is applied to Port's PortProfile.name. 
 
 | 
| 
 | 
| Set the owner RTObject of the Port. This operation sets the owner RTObject of this Port. 
 
 | 
| 
 | 
| Set the object reference of this Port. This operation sets the object reference itself to the Port's PortProfile. 
 
 | 
| 
 | 
| Create and set the UUID to the ConnectorProfile. This operation generates and set UUID to the ConnectorProfile. 
 
 | 
| 
 | 
| Publish interface information. This operation is pure virutal method that would be called at the mid-flow of the notify_connect() process sequence. In the notify_connect(), the following methods would be called in order. 
 
In the concrete Port, this method should be overridden. This method processes the given ConnectorProfile argument and if the given parameter is invalid, it would return error code of ReturnCode_t. The given argument ConnectorProfile includes all the interfaces information in it. Usually, subscribeInterafaces() method obtains information of interfaces from ConnectorProfile, and should set it to the interfaces that require them.  
 
 
 Implemented in RTC::CorbaPort, RTC::DataInPort, and RTC::DataOutPort. | 
| 
 | 
| Disconnect interface connection. This operation is pure virutal method that would be called at the end of the notify_disconnect() process sequence. In the notify_disconnect(), the following methods would be called. 
 
 
 Implemented in RTC::CorbaPort, RTC::DataInPort, and RTC::DataOutPort. | 
| 
 | 
| Append or update the ConnectorProfile list. This operation appends or updates ConnectorProfile of the Port by the given ConnectorProfile. If the connector_id of the given ConnectorProfile does not exist in the Port's ConnectorProfile list, the given ConnectorProfile would be append to the list. If the same id exists, the list would be updated. 
 
 | 
| 
 | 
| 
 | 
| 
 | 
| PortProfile of the Port. 
 | 
| 
 | 
| 
 | 
 1.4.1
 1.4.1