#include <SCIOP_Profile.h>
Inheritance diagram for TAO_SCIOP_Profile:
Public Member Functions | |
virtual char | object_key_delimiter (void) const |
TAO_SCIOP_Profile (const ACE_INET_Addr &addr, const TAO::ObjectKey &object_key, const TAO_GIOP_Message_Version &version, TAO_ORB_Core *orb_core) | |
TAO_SCIOP_Profile (const char *host, CORBA::UShort port, const TAO::ObjectKey &object_key, const ACE_INET_Addr &addr, const TAO_GIOP_Message_Version &version, TAO_ORB_Core *orb_core) | |
TAO_SCIOP_Profile (TAO_ORB_Core *orb_core) | |
Profile constructor, default. | |
~TAO_SCIOP_Profile (void) | |
Destructor is to be called only through <_decr_refcnt>. | |
virtual char * | to_string (ACE_ENV_SINGLE_ARG_DECL) |
Template methods. Please see Profile.h for documentation. | |
virtual int | encode_endpoints (void) |
virtual TAO_Endpoint * | endpoint (void) |
virtual CORBA::ULong | endpoint_count (void) const |
virtual CORBA::ULong | hash (CORBA::ULong max ACE_ENV_ARG_DECL) |
void | add_endpoint (TAO_SCIOP_Endpoint *endp) |
Static Public Member Functions | |
const char * | prefix (void) |
Return the char string prefix. | |
Static Public Attributes | |
const char | object_key_delimiter_ = '/' |
The object key delimiter that SCIOP uses or expects. | |
Protected Member Functions | |
virtual int | decode_profile (TAO_InputCDR &cdr) |
Template methods. Please see Profile.h for the documentation. | |
virtual int | decode_endpoints (void) |
virtual void | parse_string_i (const char *string ACE_ENV_ARG_DECL) |
virtual void | create_profile_body (TAO_OutputCDR &cdr) const |
virtual CORBA::Boolean | do_is_equivalent (const TAO_Profile *other_profile) |
Protected Attributes | |
TAO_SCIOP_Endpoint | endpoint_ |
CORBA::ULong | count_ |
Number of endpoints in the list headed by <endpoint_>. |
This class defines the SCIOP profile as specified in the CORBA specification.
|
Profile constructor, same as above except the object_key has already been marshaled. |
|
Profile constructor, this is the most efficient since it doesn't require any address resolution processing. |
|
Profile constructor, default.
|
|
Destructor is to be called only through <_decr_refcnt>.
|
|
Add <endp> to this profile's list of endpoints (it is inserted next to the head of the list). This profiles takes ownership of <endp>. |
|
Implements TAO_Profile. |
|
Implements TAO_Profile. |
|
Template methods. Please see Profile.h for the documentation.
Implements TAO_Profile. |
|
Implements TAO_Profile. |
|
Implements TAO_Profile. |
|
Implements TAO_Profile. |
|
Implements TAO_Profile. |
|
Implements TAO_Profile. |
|
Implements TAO_Profile. |
|
Implements TAO_Profile. |
|
Return the char string prefix.
|
|
Template methods. Please see Profile.h for documentation.
Implements TAO_Profile. |
|
Number of endpoints in the list headed by <endpoint_>.
|
|
Head of this profile's list of endpoints. This endpoint is not dynamically allocated because a profile always contains at least one endpoint. Currently, a profile contains more than one endpoint, i.e., list contains more than just the head, only for two cases (1) when RTCORBA is enabled and (2) the ORB is initialized with -ORBPreferredInterfaces option. However, in the near future, this will be used in for mode as well, e.g., to support TAG_ALTERNATE_IIOP_ADDRESS feature. This is probably as good a place to discuss how the list of endpoints is used for #2. If the ORB is configured to use preferred interfaces for invocation, TAO creates an endpoint per preferred interface. To be clear, every tuple <destination:target> will have an endpoint. What TAO essentially does is that creates it multiple endpoints so that the invocation code path can use existing iterating techniques to try one preferred interface after another (if the first did not work). If the ORB is configured with -ORBEnforcePreferredInterface set to false in addition to the ORBPreferredInterfaces option , TAO creates another endpoint with the preferred bit set to null, so that the invocation code can fall back to a SCTP stack returned local address. Addressing info of the default endpoint, i.e., head of the list, is transmitted using standard SCIOP ProfileBody components. See <encode_endpoints> method documentation above for how the rest of the endpoint list is transmitted. |
|
The object key delimiter that SCIOP uses or expects.
|