#include <UIPMC_Profile.h>
Inheritance diagram for TAO_UIPMC_Profile:
Public Methods | |
virtual char | object_key_delimiter (void) const |
TAO_UIPMC_Profile (TAO_ORB_Core *orb_core) | |
TAO_UIPMC_Profile (const ACE_INET_Addr &addr, TAO_ORB_Core *orb_core) | |
TAO_UIPMC_Profile (const CORBA::Octet class_d_address[4], CORBA::UShort port, TAO_ORB_Core *orb_core) | |
Profile constructor. | |
TAO_UIPMC_Profile (const char *string, TAO_ORB_Core *orb_core ACE_ENV_ARG_DECL_WITH_DEFAULTS) | |
Create object using a string ior. | |
~TAO_UIPMC_Profile (void) | |
Destructor is to be called only through <_decr_refcnt>. | |
virtual void | parse_string (const char *string ACE_ENV_ARG_DECL) |
virtual char * | to_string (ACE_ENV_SINGLE_ARG_DECL) |
virtual int | decode (TAO_InputCDR &cdr) |
Initialize this object using the given CDR octet string. | |
virtual int | encode (TAO_OutputCDR &stream) const |
Encode this profile in a stream, i.e. marshal it. | |
virtual int | encode_endpoints (void) |
virtual const TAO_ObjectKey & | object_key (void) const |
deprecated. return a reference to the Object Key. | |
virtual TAO_ObjectKey * | _key (void) const |
virtual TAO_Endpoint * | endpoint (void) |
Return pointer to the head of this profile's endpoints list. | |
virtual size_t | endpoint_count (void) |
Return how many endpoints this profile contains. | |
virtual CORBA::Boolean | is_equivalent (const TAO_Profile *other_profile) |
virtual CORBA::ULong | hash (CORBA::ULong max ACE_ENV_ARG_DECL_WITH_DEFAULTS) |
Return a hash value for this object. | |
virtual IOP::TaggedProfile & | create_tagged_profile (void) |
virtual void | request_target_specifier (TAO_Target_Specification &target_spec, TAO_Target_Specification::TAO_Target_Address required_type ACE_ENV_ARG_DECL) |
virtual int | supports_multicast (void) const |
Returns true since this profile can specify multicast endpoints. | |
void | set_group_info (const char *domain_id, PortableGroup::ObjectGroupId group_id, PortableGroup::ObjectGroupRefVersion ref_version) |
Add the mandatory group component to this profile. | |
virtual void | addressing_mode (CORBA::Short addr_mode ACE_ENV_ARG_DECL) |
Static Public Methods | |
const char * | prefix (void) |
Return the char string prefix. | |
int | extract_group_component (const IOP::TaggedProfile &profile, PortableGroup::TagGroupTaggedComponent &group) |
Static Public Attributes | |
const char | object_key_delimiter_ = '/' |
The object key delimiter that UIPMC uses or expects. | |
Protected Attributes | |
TAO_UIPMC_Endpoint | endpoint_ |
size_t | count_ |
Number of endpoints in the list headed by <endpoint_>. | |
Private Methods | |
void | create_profile_body (TAO_OutputCDR &cdr) const |
Creates an encapsulation of the ProfileBody struct in the <cdr>. | |
void | update_cached_group_component (void) |
Private Attributes | |
TAO_ObjectKey | object_key_ |
IOP::TaggedProfile | tagged_profile_ |
Cached version of our tagged profile. | |
ACE_CString | group_domain_id_ |
Group Domain ID. | |
PortableGroup::ObjectGroupId | group_id_ |
Our group ID within the group domain. | |
PortableGroup::ObjectGroupRefVersion | ref_version_ |
The group reference's version. |
This class defines the UIPMC profile as specified in the CORBA specification.
|
Profile constructor, default. Used when the profile contents are not yet known or when it is being decoded from an IOR. |
|
Profile constructor, same as above except the object_key has already been marshaled. |
|
Profile constructor.
|
|
Create object using a string ior.
|
|
Destructor is to be called only through <_decr_refcnt>.
|
|
Return a pointer to the Object Key. The caller owns the memory allocated for the returned key. Implements TAO_Profile. |
|
Set and validate the addressing mode if the remote ORB returns an exception. Reimplemented from TAO_Profile. |
|
Creates an encapsulation of the ProfileBody struct in the <cdr>.
|
|
Please refer to Profile.h for the documentation of this function. Implements TAO_Profile. |
|
Initialize this object using the given CDR octet string.
Implements TAO_Profile. |
|
Encode this profile in a stream, i.e. marshal it.
Implements TAO_Profile. |
|
Encodes this profile's endpoints into a tagged component. This is done only if RTCORBA is enabled, since currently this is the only case when we have more than one endpoint per profile. Returns 0 on success and -1 on failure. Endpoints are transmitted using TAO-proprietory tagged component. Component tag is TAO_TAG_ENDPOINTS and component data is an encapsulation of a sequence of structs, each representing a single endpoint. Data format is specified in iiop_endpoins.pidl. Multiple TAG_ALTERNATE_UIPMC_ADDRESS components can be used instead of a single proprietory component to transmit multiple endpoints. This is somewhat slower and less convenient. Also, TAG_ALTERNATE_UIPMC_ADDRESS does not provide for transmission of endpoint priorities. Implements TAO_Profile. |
|
Return pointer to the head of this profile's endpoints list.
Implements TAO_Profile. |
|
Return how many endpoints this profile contains.
Implements TAO_Profile. |
|
|
|
Return a hash value for this object.
Implements TAO_Profile. |
|
Return true if this profile is equivalent to other_profile. Two profiles are equivalent iff their tag, object_key, version and all endpoints are the same. Implements TAO_Profile. |
|
deprecated. return a reference to the Object Key. @ Implements TAO_Profile. |
|
Implements TAO_Profile. |
|
Initialize this object using the given input string. Url-style string contain only one endpoint. Implements TAO_Profile. |
|
Return the char string prefix.
|
|
Set the request target specifier to point to a tagged profile containing the GroupId associated with this profile. |
|
Add the mandatory group component to this profile.
|
|
Returns true since this profile can specify multicast endpoints.
Reimplemented from TAO_Profile. |
|
Return a string representation for this profile. client must deallocate memory. This is used to create url-style reference. Only one endpoint is included into the string. Implements TAO_Profile. |
|
Update the group component in the cached list of tagged components. This needs to be called whenever the group_domain_id, group_id, or ref_version changes. |
|
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 when RTCORBA is enabled. However, in the near future, this will be used in nonRT mode as well, e.g., to support TAG_ALTERNATE_IIOP_ADDRESS feature. Addressing info of the default endpoint, i.e., head of the list, is transmitted using standard UIPMC ProfileBody components. See <encode_endpoints> method documentation above for how the rest of the endpoint list is transmitted. |
|
Group Domain ID.
|
|
Our group ID within the group domain.
|
|
object_key associated with this profile. This is wasted data for UIPMC since there is no object key here, but is needed to satisfy some of the API calls. |
|
The object key delimiter that UIPMC uses or expects.
|
|
The group reference's version.
|
|
Cached version of our tagged profile.
|