#include <Sequence_TypeCode_Static.h>
Inheritance diagram for TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >:
@c TAO CORBA::TypeCode Template Methods | |
CORBA::TypeCode template methods specific to tk_sequence TypeCodes .
| |
virtual CORBA::Boolean | equal_i (CORBA::TypeCode_ptr tc) const |
virtual CORBA::Boolean | equivalent_i (CORBA::TypeCode_ptr tc) const |
virtual CORBA::TypeCode_ptr | get_compact_typecode_i (void) const |
virtual CORBA::ULong | length_i (void) const |
virtual CORBA::TypeCode_ptr | content_type_i (void) const |
CORBA::TypeCode_ptr const *const | content_type_ |
Element type of the sequence. | |
CORBA::ULong const | length_ |
Public Member Functions | |
Sequence (CORBA::TCKind kind, CORBA::TypeCode_ptr const *content_type, CORBA::ULong length) | |
Constructor. | |
TAO-specific @c CORBA::TypeCode Methods | |
virtual bool | tao_marshal (TAO_OutputCDR &cdr, CORBA::ULong offset) const |
Marshal this TypeCode into a CDR output stream. | |
virtual void | tao_duplicate (void) |
Increase the reference count on this TypeCode . | |
virtual void | tao_release (void) |
Decrease the reference count on this object. |
Definition at line 47 of file Sequence_TypeCode_Static.h.
TAO_BEGIN_VERSIONED_NAMESPACE_DECL ACE_INLINE TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::Sequence | ( | CORBA::TCKind | kind, | |
CORBA::TypeCode_ptr const * | content_type, | |||
CORBA::ULong | length | |||
) |
Constructor.
Definition at line 9 of file Sequence_TypeCode_Static.inl.
00013 : ::CORBA::TypeCode (kind) 00014 , ::TAO::Null_RefCount_Policy () 00015 , content_type_ (content_type) 00016 , length_ (length) 00017 { 00018 }
CORBA::TypeCode_ptr TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::content_type_i | ( | void | ) | const [protected, virtual] |
Reimplemented from CORBA::TypeCode.
Definition at line 138 of file Sequence_TypeCode_Static.cpp.
References CORBA::TypeCode::_duplicate().
00140 { 00141 return 00142 CORBA::TypeCode::_duplicate ( 00143 Traits<CORBA::TypeCode_ptr const *>::get_typecode (this->content_type_)); 00144 }
CORBA::Boolean TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::equal_i | ( | CORBA::TypeCode_ptr | tc | ) | const [protected, virtual] |
Implements CORBA::TypeCode.
Definition at line 65 of file Sequence_TypeCode_Static.cpp.
References TAO_Pseudo_Var_T< T >::in().
00068 { 00069 // The following calls won't throw since CORBA::TypeCode::equal() 00070 // has already established the kind of tc is the same as our kind. 00071 CORBA::ULong const tc_length = tc->length (); 00072 00073 if (this->length_ != tc_length) 00074 return false; 00075 00076 CORBA::TypeCode_var rhs_content_type = 00077 tc->content_type (); 00078 00079 return 00080 Traits<CORBA::TypeCode_ptr const *>::get_typecode (this->content_type_)->equal ( 00081 rhs_content_type.in () 00082 ); 00083 }
CORBA::Boolean TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::equivalent_i | ( | CORBA::TypeCode_ptr | tc | ) | const [protected, virtual] |
Implements CORBA::TypeCode.
Definition at line 87 of file Sequence_TypeCode_Static.cpp.
References TAO_Pseudo_Var_T< T >::in().
00090 { 00091 // The following calls won't throw since CORBA::TypeCode::equal() 00092 // has already established the kind of tc is the same as our kind. 00093 CORBA::ULong const tc_length = tc->length (); 00094 00095 if (this->length_ != tc_length) 00096 return 0; 00097 00098 CORBA::TypeCode_var rhs_content_type = 00099 tc->content_type (); 00100 00101 return 00102 Traits<CORBA::TypeCode_ptr const *>::get_typecode (this->content_type_)->equivalent ( 00103 rhs_content_type.in () 00104 ); 00105 }
CORBA::TypeCode_ptr TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::get_compact_typecode_i | ( | void | ) | const [protected, virtual] |
Implements CORBA::TypeCode.
Definition at line 109 of file Sequence_TypeCode_Static.cpp.
References CORBA::TypeCode::_duplicate().
00111 { 00112 // Already compact since tk_sequence and tk_array TypeCodes have no 00113 // name or member names, meaning that we can simply call 00114 // _duplicate() on this TypeCode. 00115 00116 // @@ There is a potential problem here if this TypeCode is a static 00117 // and const since it may have been placed in read-only memory by 00118 // the compiler. A const_cast<> can return undefined results in 00119 // that case. 00120 00121 CORBA::TypeCode_ptr mutable_tc = 00122 const_cast<TAO::TypeCode::Sequence<CORBA::TypeCode_ptr const *, 00123 TAO::Null_RefCount_Policy> *> (this); 00124 00125 return CORBA::TypeCode::_duplicate (mutable_tc); 00126 }
CORBA::ULong TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::length_i | ( | void | ) | const [protected, virtual] |
Reimplemented from CORBA::TypeCode.
Definition at line 130 of file Sequence_TypeCode_Static.cpp.
00132 { 00133 return this->length_; 00134 }
void TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::tao_duplicate | ( | void | ) | [virtual] |
Increase the reference count on this TypeCode
.
Implements CORBA::TypeCode.
Definition at line 53 of file Sequence_TypeCode_Static.cpp.
TAO_BEGIN_VERSIONED_NAMESPACE_DECL bool TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::tao_marshal | ( | TAO_OutputCDR & | cdr, | |
CORBA::ULong | offset | |||
) | const [virtual] |
Marshal this TypeCode
into a CDR output stream.
Marshal this TypeCode
into the cdr output CDR stream, excluding the TypeCode
kind. Existing cdr contents will not be altered. The marshaled TypeCode
will be appended to the given cdr CDR output stream.
cdr | Output CDR stream into which the TypeCode will be marshaled. | |
offset | Number of bytes currently in the output CDR stream, including the top-level TypeCode TCKind . This argument is useful for recursive TypeCodes . TypeCodes that contain other TypeCodes should pass an updated offset value to the marshaling operation for those contained TypeCodes . |
true
if marshaling was successful.CORBA::TypeCode
interface.If this method returns false, the contents of the cdr output CDR stream are undefined.
Implements CORBA::TypeCode.
Definition at line 20 of file Sequence_TypeCode_Static.cpp.
References ACE_align_binary(), ACE_OutputCDR::begin(), ACE_CDR::OCTET_ALIGN, TAO_ENCAP_BYTE_ORDER, ACE_OutputCDR::total_length(), and ACE_OutputCDR::write_octet_array_mb().
00023 { 00024 // A tk_array or tk_sequence TypeCode has a "complex" parameter list 00025 // type (see Table 15-2 in Section 15.3.5.1 "TypeCode" in the CDR 00026 // section of the CORBA specification), meaning that it must be 00027 // marshaled into a CDR encapsulation. 00028 00029 // Create a CDR encapsulation. 00030 TAO_OutputCDR enc; 00031 00032 // Account for the encoded CDR encapsulation length and byte order. 00033 // 00034 // Aligning on an octet since the next value after the CDR 00035 // encapsulation length will always be the byte order octet/boolean 00036 // in this case. 00037 offset = ACE_align_binary (offset + 4, 00038 ACE_CDR::OCTET_ALIGN); 00039 00040 return 00041 enc << TAO_OutputCDR::from_boolean (TAO_ENCAP_BYTE_ORDER) 00042 && marshal (enc, 00043 Traits<CORBA::TypeCode_ptr const *>::get_typecode ( 00044 this->content_type_), 00045 offset + enc.total_length ()) 00046 && enc << this->length_ 00047 && cdr << static_cast<CORBA::ULong> (enc.total_length ()) 00048 && cdr.write_octet_array_mb (enc.begin ()); 00049 }
void TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::tao_release | ( | void | ) | [virtual] |
Decrease the reference count on this object.
Implements CORBA::TypeCode.
Definition at line 59 of file Sequence_TypeCode_Static.cpp.
CORBA::TypeCode_ptr const* const TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::content_type_ [private] |
Element type of the sequence.
A pointer to the CORBA::TypeCode_ptr
rather than the CORBA::TypeCode_ptr
itself is stored since that address is well-defined. We may not know the value of the CORBA::TypeCode_ptr
when creating this Field
statically at compile-time, hence the indirection.
TypeCode
is released upon destruction of this TypeCode::Sequence
. Definition at line 108 of file Sequence_TypeCode_Static.h.
CORBA::ULong const TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::length_ [private] |
Length of the sequence
or array. A length of zero indicates an unbounded sequence
.
Definition at line 112 of file Sequence_TypeCode_Static.h.