#include <Sequence_TypeCode_Static.h>
Public Member Functions | |
Sequence (CORBA::TCKind kind, CORBA::TypeCode_ptr const *content_type, CORBA::ULong length) | |
Constructor. | |
TAO-specific @c CORBA::TypeCode Methods | |
Methods required by TAO's implementation of the
| |
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. | |
@c TAO CORBA::TypeCode Template Methods | |
| |
CORBA::TypeCode_ptr const *const | content_type_ |
Element type of the sequence. | |
CORBA::ULong const | length_ |
virtual CORBA::Boolean | equal_i (CORBA::TypeCode_ptr tc) const |
Element type of the sequence. | |
virtual CORBA::Boolean | equivalent_i (CORBA::TypeCode_ptr tc) const |
Element type of the sequence. | |
virtual CORBA::TypeCode_ptr | get_compact_typecode_i (void) const |
Element type of the sequence. | |
virtual CORBA::ULong | length_i (void) const |
Element type of the sequence. | |
virtual CORBA::TypeCode_ptr | content_type_i (void) const |
Element type of the sequence. |
Definition at line 47 of file Sequence_TypeCode_Static.h.
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.
: ::CORBA::TypeCode (kind) , ::TAO::Null_RefCount_Policy () , content_type_ (content_type) , length_ (length) { }
CORBA::TypeCode_ptr TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::content_type_i | ( | void | ) | const [protected, virtual] |
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
. Reimplemented from CORBA::TypeCode.
Definition at line 138 of file Sequence_TypeCode_Static.cpp.
{ return CORBA::TypeCode::_duplicate ( Traits<CORBA::TypeCode_ptr const *>::get_typecode (this->content_type_)); }
CORBA::Boolean TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::equal_i | ( | CORBA::TypeCode_ptr | tc | ) | const [protected, virtual] |
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
. Implements CORBA::TypeCode.
Definition at line 65 of file Sequence_TypeCode_Static.cpp.
{ // The following calls won't throw since CORBA::TypeCode::equal() // has already established the kind of tc is the same as our kind. CORBA::ULong const tc_length = tc->length (); if (this->length_ != tc_length) return false; CORBA::TypeCode_var rhs_content_type = tc->content_type (); return Traits<CORBA::TypeCode_ptr const *>::get_typecode (this->content_type_)->equal ( rhs_content_type.in () ); }
CORBA::Boolean TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::equivalent_i | ( | CORBA::TypeCode_ptr | tc | ) | const [protected, virtual] |
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
. Implements CORBA::TypeCode.
Definition at line 87 of file Sequence_TypeCode_Static.cpp.
{ // The following calls won't throw since CORBA::TypeCode::equal() // has already established the kind of tc is the same as our kind. CORBA::ULong const tc_length = tc->length (); if (this->length_ != tc_length) return 0; CORBA::TypeCode_var rhs_content_type = tc->content_type (); return Traits<CORBA::TypeCode_ptr const *>::get_typecode (this->content_type_)->equivalent ( rhs_content_type.in () ); }
CORBA::TypeCode_ptr TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::get_compact_typecode_i | ( | void | ) | const [protected, virtual] |
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
. Implements CORBA::TypeCode.
Definition at line 109 of file Sequence_TypeCode_Static.cpp.
{ // Already compact since tk_sequence and tk_array TypeCodes have no // name or member names, meaning that we can simply call // _duplicate() on this TypeCode. // @@ There is a potential problem here if this TypeCode is a static // and const since it may have been placed in read-only memory by // the compiler. A const_cast<> can return undefined results in // that case. CORBA::TypeCode_ptr mutable_tc = const_cast<TAO::TypeCode::Sequence<CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy> *> (this); return CORBA::TypeCode::_duplicate (mutable_tc); }
CORBA::ULong TAO::TypeCode::Sequence< CORBA::TypeCode_ptr const *, TAO::Null_RefCount_Policy >::length_i | ( | void | ) | const [protected, virtual] |
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
. Reimplemented from CORBA::TypeCode.
Definition at line 130 of file Sequence_TypeCode_Static.cpp.
{ return this->length_; }
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.
{ }
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.Implements CORBA::TypeCode.
Definition at line 20 of file Sequence_TypeCode_Static.cpp.
{ // A tk_array or tk_sequence TypeCode has a "complex" parameter list // type (see Table 15-2 in Section 15.3.5.1 "TypeCode" in the CDR // section of the CORBA specification), meaning that it must be // marshaled into a CDR encapsulation. // Create a CDR encapsulation. TAO_OutputCDR enc; // Account for the encoded CDR encapsulation length and byte order. // // Aligning on an octet since the next value after the CDR // encapsulation length will always be the byte order octet/boolean // in this case. offset = ACE_align_binary (offset + 4, ACE_CDR::OCTET_ALIGN); return enc << TAO_OutputCDR::from_boolean (TAO_ENCAP_BYTE_ORDER) && marshal (enc, Traits<CORBA::TypeCode_ptr const *>::get_typecode ( this->content_type_), offset + enc.total_length ()) && enc << this->length_ && cdr << static_cast<CORBA::ULong> (enc.total_length ()) && cdr.write_octet_array_mb (enc.begin ()); }
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.