#include <DynStruct_i.h>
Public Member Functions | |
TAO_DynStruct_i (void) | |
Constructor. | |
~TAO_DynStruct_i (void) | |
Destructor. | |
void | init (CORBA::TypeCode_ptr tc) |
Initialize using just a TypeCode. | |
void | init (const CORBA::Any &any) |
Initialize using an Any. | |
virtual DynamicAny::FieldName | current_member_name (void) |
virtual CORBA::TCKind | current_member_kind (void) |
virtual DynamicAny::NameValuePairSeq * | get_members (void) |
virtual void | set_members (const DynamicAny::NameValuePairSeq &value) |
virtual DynamicAny::NameDynAnyPairSeq * | get_members_as_dyn_any (void) |
virtual void | set_members_as_dyn_any (const DynamicAny::NameDynAnyPairSeq &value) |
virtual void | from_any (const CORBA::Any &value) |
virtual CORBA::Any * | to_any (void) |
virtual CORBA::Boolean | equal (DynamicAny::DynAny_ptr dyn_any) |
virtual void | destroy (void) |
virtual DynamicAny::DynAny_ptr | current_component (void) |
Static Public Member Functions | |
static TAO_DynStruct_i * | _narrow (CORBA::Object_ptr obj) |
Private Member Functions | |
void | check_typecode (CORBA::TypeCode_ptr tc) |
Check if the typecode is acceptable. | |
void | set_from_any (const CORBA::Any &any) |
void | init_common (void) |
Called by both versions of init(). | |
TAO_DynStruct_i (const TAO_DynStruct_i &src) | |
TAO_DynStruct_i & | operator= (const TAO_DynStruct_i &src) |
Private Attributes | |
ACE_Array_Base < DynamicAny::DynAny_var > | da_members_ |
Each component is also a DynAny. |
Implementation of Dynamic Any type for Structs
Definition at line 42 of file DynStruct_i.h.
TAO_DynStruct_i::TAO_DynStruct_i | ( | void | ) |
TAO_DynStruct_i::~TAO_DynStruct_i | ( | void | ) |
TAO_DynStruct_i::TAO_DynStruct_i | ( | const TAO_DynStruct_i & | src | ) | [private] |
TAO_DynStruct_i * TAO_DynStruct_i::_narrow | ( | CORBA::Object_ptr | obj | ) | [static] |
is_local
member into CORBA::Object. I'll take the easier route for now. Reimplemented from CORBA::LocalObject.
Definition at line 171 of file DynStruct_i.cpp.
{ if (CORBA::is_nil (_tao_objref)) { return 0; } return dynamic_cast<TAO_DynStruct_i *> (_tao_objref); }
void TAO_DynStruct_i::check_typecode | ( | CORBA::TypeCode_ptr | tc | ) | [private] |
Check if the typecode is acceptable.
Definition at line 28 of file DynStruct_i.cpp.
{ CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc); if (kind == CORBA::tk_struct || kind == CORBA::tk_except) { return; } throw DynamicAny::DynAnyFactory::InconsistentTypeCode (); }
DynamicAny::DynAny_ptr TAO_DynStruct_i::current_component | ( | void | ) | [virtual] |
Definition at line 644 of file DynStruct_i.cpp.
{ if (this->destroyed_) { throw ::CORBA::OBJECT_NOT_EXIST (); } if (this->component_count_ == 0) { // Empty exception - no component. throw DynamicAny::DynAny::TypeMismatch (); } if (this->current_position_ == -1) { return DynamicAny::DynAny::_nil (); } CORBA::ULong index = static_cast <CORBA::ULong> (this->current_position_); this->set_flag (this->da_members_[index].in (), 0); return DynamicAny::DynAny::_duplicate (this->da_members_[index].in ()); }
CORBA::TCKind TAO_DynStruct_i::current_member_kind | ( | void | ) | [virtual] |
Definition at line 213 of file DynStruct_i.cpp.
{ if (this->destroyed_) { throw ::CORBA::OBJECT_NOT_EXIST (); } // Is this an empty exception? if (this->component_count_ == 0) { throw DynamicAny::DynAny::TypeMismatch (); } if (this->current_position_ == -1) { throw DynamicAny::DynAny::InvalidValue (); } // member_type() does not work with aliased type codes. CORBA::TypeCode_var unaliased_tc = TAO_DynAnyFactory::strip_alias (this->type_.in ()); CORBA::TypeCode_var tc = unaliased_tc->member_type (this->current_position_); CORBA::TCKind retval = TAO_DynAnyFactory::unalias (tc.in ()); return retval; }
DynamicAny::FieldName TAO_DynStruct_i::current_member_name | ( | void | ) | [virtual] |
Definition at line 184 of file DynStruct_i.cpp.
{ if (this->destroyed_) { throw ::CORBA::OBJECT_NOT_EXIST (); } // Is this an empty exception? if (this->component_count_ == 0) { throw DynamicAny::DynAny::TypeMismatch (); } if (this->current_position_ == -1) { throw DynamicAny::DynAny::InvalidValue (); } // member_name() does not work with aliased type codes. CORBA::TypeCode_var unaliased_tc = TAO_DynAnyFactory::strip_alias (this->type_.in ()); const char *name = unaliased_tc->member_name (this->current_position_); return CORBA::string_dup (name); }
void TAO_DynStruct_i::destroy | ( | void | ) | [virtual] |
Definition at line 622 of file DynStruct_i.cpp.
{ if (this->destroyed_) { throw ::CORBA::OBJECT_NOT_EXIST (); } if (!this->ref_to_component_ || this->container_is_destroying_) { // Do a deep destroy. for (CORBA::ULong i = 0; i < this->component_count_; ++i) { this->set_flag (da_members_[i].in (), 1); this->da_members_[i]->destroy (); } this->destroyed_ = 1; } }
CORBA::Boolean TAO_DynStruct_i::equal | ( | DynamicAny::DynAny_ptr | dyn_any | ) | [virtual] |
Definition at line 586 of file DynStruct_i.cpp.
{ if (this->destroyed_) { throw ::CORBA::OBJECT_NOT_EXIST (); } CORBA::TypeCode_var tc = rhs->type (); if (!tc->equivalent (this->type_.in ())) { return false; } DynamicAny::DynAny_var tmp; CORBA::Boolean member_equal; for (CORBA::ULong i = 0; i < this->component_count_; ++i) { rhs->seek (static_cast <CORBA::Long> (i)); tmp = rhs->current_component (); // Recursive step. member_equal = tmp->equal (this->da_members_[i].in ()); if (!member_equal) { return 0; } } return true; }
void TAO_DynStruct_i::from_any | ( | const CORBA::Any & | value | ) | [virtual] |
Definition at line 430 of file DynStruct_i.cpp.
{ if (this->destroyed_) { throw ::CORBA::OBJECT_NOT_EXIST (); } CORBA::TypeCode_var tc = any.type (); CORBA::Boolean equivalent = this->type_->equivalent (tc.in () ); if (equivalent) { // Get the CDR stream of the Any, if there isn't one, make one. TAO::Any_Impl *impl = any.impl (); TAO_OutputCDR out; TAO_InputCDR in (static_cast<ACE_Message_Block *> (0)); TAO::Unknown_IDL_Type *unk = 0; if (impl->encoded ()) { unk = dynamic_cast<TAO::Unknown_IDL_Type *> (impl); if (!unk) throw CORBA::INTERNAL (); in = unk->_tao_get_cdr (); } else { impl->marshal_value (out); TAO_InputCDR tmp_in (out); in = tmp_in; } // If we have an exception type, unmarshal the repository ID. CORBA::TCKind kind = TAO_DynAnyFactory::unalias (this->type_.in ()); if (kind == CORBA::tk_except) { CORBA::String_var str; in >> str.out (); } CORBA::TypeCode_var field_tc; CORBA::TypeCode_var unaliased = TAO::unaliased_typecode (this->type_.in () ); for (CORBA::ULong i = 0; i < this->component_count_; ++i) { field_tc = unaliased->member_type (i); CORBA::Any field_any; TAO_InputCDR unk_in (in); TAO::Unknown_IDL_Type *unk = 0; ACE_NEW (unk, TAO::Unknown_IDL_Type (field_tc.in (), unk_in)); field_any.replace (unk); this->da_members_[i]->destroy (); this->da_members_[i] = TAO::MakeDynAnyUtils::make_dyn_any_t<const CORBA::Any&> ( field_any._tao_get_typecode (), field_any); // Move to the next field in the CDR stream. (void) TAO_Marshal_Object::perform_skip (field_tc.in (), &in); } this->current_position_ = this->component_count_ ? 0 : -1; } else { throw DynamicAny::DynAny::TypeMismatch (); } }
DynamicAny::NameValuePairSeq * TAO_DynStruct_i::get_members | ( | void | ) | [virtual] |
Definition at line 243 of file DynStruct_i.cpp.
{ if (this->destroyed_) { throw ::CORBA::OBJECT_NOT_EXIST (); } DynamicAny::NameValuePairSeq* members; ACE_NEW_THROW_EX (members, DynamicAny::NameValuePairSeq (this->component_count_), CORBA::NO_MEMORY ()); // We must do this explicitly. members->length (this->component_count_); DynamicAny::NameValuePairSeq_var safe_retval = members; CORBA::Any_var temp; CORBA::TypeCode_var unaliased_tc; CORBA::TCKind const tc_kind = this->type_->kind (); if (tc_kind == CORBA::tk_alias) { unaliased_tc = TAO_DynAnyFactory::strip_alias (this->type_.in ()); } else { unaliased_tc = CORBA::TypeCode::_duplicate (this->type_.in ()); } // Assign name and value to each pearl on the string. for (CORBA::ULong i = 0; i < this->component_count_; ++i) { safe_retval[i].id = CORBA::string_dup (unaliased_tc->member_name (i)); temp = this->da_members_[i]->to_any (); safe_retval[i].value = temp.in (); } return safe_retval._retn (); }
DynamicAny::NameDynAnyPairSeq * TAO_DynStruct_i::get_members_as_dyn_any | ( | void | ) | [virtual] |
Definition at line 339 of file DynStruct_i.cpp.
{ if (this->destroyed_) { throw ::CORBA::OBJECT_NOT_EXIST (); } DynamicAny::NameDynAnyPairSeq * members; ACE_NEW_THROW_EX (members, DynamicAny::NameDynAnyPairSeq (this->component_count_), CORBA::NO_MEMORY ()); // We must do this explicitly. members->length (this->component_count_); DynamicAny::NameDynAnyPairSeq_var safe_retval = members; // member_name() does not work with aliased type codes. CORBA::TypeCode_var unaliased_tc = TAO_DynAnyFactory::strip_alias (this->type_.in ()); // Assign name and value to each pearl on the string. for (CORBA::ULong i = 0; i < this->component_count_; ++i) { safe_retval[i].id = CORBA::string_dup (unaliased_tc->member_name (i)); // A deep copy is made only by copy() (CORBA 2.4.2 section 9.2.3.6). // Set the flag so the caller can't destroy. this->set_flag (this->da_members_[i].in (), 0); safe_retval[i].value = DynamicAny::DynAny::_duplicate (this->da_members_[i].in ()); } return safe_retval._retn (); }
void TAO_DynStruct_i::init | ( | const CORBA::Any & | any | ) |
Initialize using an Any.
Definition at line 52 of file DynStruct_i.cpp.
{ CORBA::TypeCode_ptr tc = any._tao_get_typecode (); this->check_typecode (tc); this->type_ = CORBA::TypeCode::_duplicate (tc); this->set_from_any (any); }
void TAO_DynStruct_i::init | ( | CORBA::TypeCode_ptr | tc | ) |
Initialize using just a TypeCode.
Definition at line 136 of file DynStruct_i.cpp.
{ this->check_typecode (tc); this->type_ = CORBA::TypeCode::_duplicate (tc); // member_type() does not work with aliased type codes. CORBA::TypeCode_var unaliased_tc = TAO_DynAnyFactory::strip_alias (this->type_.in ()); this->component_count_ = unaliased_tc->member_count (); // Resize the array. this->da_members_.size (this->component_count_); this->init_common (); CORBA::TypeCode_var mtype; for (CORBA::ULong i = 0; i < this->component_count_; ++i) { mtype = unaliased_tc->member_type (i); // Recursively initialize each member. this->da_members_[i] = TAO::MakeDynAnyUtils::make_dyn_any_t<CORBA::TypeCode_ptr> ( mtype.in (), mtype.in ()); } }
void TAO_DynStruct_i::init_common | ( | void | ) | [private] |
Called by both versions of init().
Definition at line 41 of file DynStruct_i.cpp.
{ this->ref_to_component_ = false; this->container_is_destroying_ = false; this->has_components_ = true; this->destroyed_ = false; this->component_count_ = static_cast <CORBA::ULong> (this->da_members_.size ()); this->current_position_ = this->component_count_ ? 0 : -1; }
TAO_DynStruct_i& TAO_DynStruct_i::operator= | ( | const TAO_DynStruct_i & | src | ) | [private] |
void TAO_DynStruct_i::set_from_any | ( | const CORBA::Any & | any | ) | [private] |
Code common to the constructor from an Any arg and the member function from_any().
Definition at line 66 of file DynStruct_i.cpp.
{ // member_type() does not work with aliased type codes. CORBA::TypeCode_var unaliased_tc = TAO_DynAnyFactory::strip_alias (any._tao_get_typecode ()); CORBA::ULong numfields = unaliased_tc->member_count (); // Resize the array. this->da_members_.size (numfields); this->init_common (); // Get the CDR stream of the Any, if there isn't one, make one. TAO::Any_Impl *impl = any.impl (); TAO_OutputCDR out; TAO_InputCDR in (static_cast<ACE_Message_Block *> (0)); TAO::Unknown_IDL_Type *unk = 0; if (impl->encoded ()) { unk = dynamic_cast<TAO::Unknown_IDL_Type *> (impl); if (!unk) throw CORBA::INTERNAL (); in = unk->_tao_get_cdr (); } else { impl->marshal_value (out); TAO_InputCDR tmp_in (out); in = tmp_in; } // If we have an exception type, unmarshal the repository ID. CORBA::TCKind kind = TAO_DynAnyFactory::unalias (any._tao_get_typecode ()); if (kind == CORBA::tk_except) { CORBA::String_var str; in >> str.out (); } for (CORBA::ULong i = 0; i < numfields; i++) { CORBA::TypeCode_var field_tc = unaliased_tc->member_type (i); CORBA::Any field_any; TAO_InputCDR unk_in (in); ACE_NEW (unk, TAO::Unknown_IDL_Type (field_tc.in (), unk_in)); field_any.replace (unk); // This recursive step will call the correct constructor // based on the type of field_any. this->da_members_[i] = TAO::MakeDynAnyUtils::make_dyn_any_t<const CORBA::Any&> ( field_any._tao_get_typecode (), field_any); // Move to the next field in the CDR stream. (void) TAO_Marshal_Object::perform_skip (field_tc.in (), &in); } }
void TAO_DynStruct_i::set_members | ( | const DynamicAny::NameValuePairSeq & | value | ) | [virtual] |
Definition at line 289 of file DynStruct_i.cpp.
{ if (this->destroyed_) { throw ::CORBA::OBJECT_NOT_EXIST (); } CORBA::ULong length = values.length (); // Check for length match. if (length != this->component_count_) { throw DynamicAny::DynAny::InvalidValue (); } CORBA::TypeCode_var value_tc; CORBA::TypeCode_var my_tc; CORBA::Boolean equivalent; // member_type() does not work with aliased type codes. CORBA::TypeCode_var unaliased_tc = TAO_DynAnyFactory::strip_alias (this->type_.in () ); for (CORBA::ULong i = 0; i < length; ++i) { // Check for type and name match. my_tc = unaliased_tc->member_type (i); value_tc = values[i].value.type (); equivalent = my_tc->equivalent (value_tc.in ()); if (!equivalent) { throw DynamicAny::DynAny::TypeMismatch (); } this->da_members_[i]->destroy (); this->da_members_[i] = TAO::MakeDynAnyUtils::make_dyn_any_t<const CORBA::Any&> ( values[i].value._tao_get_typecode (), values[i].value); } this->current_position_ = length ? 0 : -1; }
void TAO_DynStruct_i::set_members_as_dyn_any | ( | const DynamicAny::NameDynAnyPairSeq & | value | ) | [virtual] |
Definition at line 377 of file DynStruct_i.cpp.
{ if (this->destroyed_) { throw ::CORBA::OBJECT_NOT_EXIST (); } CORBA::ULong length = values.length (); // Check for length match. if (length != this->component_count_) { throw DynamicAny::DynAny::InvalidValue (); } CORBA::TypeCode_var value_tc; CORBA::TypeCode_var my_tc; CORBA::Boolean equivalent; // member_type() does not work with aliased type codes. CORBA::TypeCode_var unaliased_tc = TAO_DynAnyFactory::strip_alias (this->type_.in () ); for (CORBA::ULong i = 0; i < length; ++i) { // Check for type and name match. my_tc = unaliased_tc->member_type (i); value_tc = values[i].value->type (); equivalent = my_tc->equivalent (value_tc.in ()); if (!equivalent) { throw DynamicAny::DynAny::TypeMismatch (); } this->da_members_[i]->destroy (); this->da_members_[i] = values[i].value->copy (); } this->current_position_ = length ? 0 : -1; }
CORBA::Any_ptr TAO_DynStruct_i::to_any | ( | void | ) | [virtual] |
Definition at line 513 of file DynStruct_i.cpp.
{ if (this->destroyed_) { throw ::CORBA::OBJECT_NOT_EXIST (); } TAO_OutputCDR out_cdr; // If we have an exception type, marshal the repository ID. CORBA::TCKind kind = TAO_DynAnyFactory::unalias (this->type_.in ()); if (kind == CORBA::tk_except) { out_cdr << this->type_->id (); } TAO::Any_Impl *field_impl = 0; TAO::Unknown_IDL_Type *field_unk = 0; TAO_InputCDR field_in_cdr (static_cast<ACE_Message_Block *> (0)); for (CORBA::ULong i = 0; i < this->component_count_; ++i) { CORBA::TypeCode_var field_tc = this->da_members_[i]->type (); // Recursive step. CORBA::Any_var field_any = this->da_members_[i]->to_any (); TAO_OutputCDR field_out_cdr; field_impl = field_any->impl (); if (field_impl->encoded ()) { field_unk = dynamic_cast<TAO::Unknown_IDL_Type *> (field_impl); if (!field_unk) throw CORBA::INTERNAL (); field_in_cdr = field_unk->_tao_get_cdr (); } else { field_impl->marshal_value (field_out_cdr); TAO_InputCDR tmp (field_out_cdr); field_in_cdr = tmp; } (void) TAO_Marshal_Object::perform_append (field_tc.in (), &field_in_cdr, &out_cdr); } TAO_InputCDR in_cdr (out_cdr); CORBA::Any_ptr retval = 0; ACE_NEW_THROW_EX (retval, CORBA::Any, CORBA::NO_MEMORY ()); TAO::Unknown_IDL_Type *unk = 0; ACE_NEW_THROW_EX (unk, TAO::Unknown_IDL_Type (this->type_.in (), in_cdr), CORBA::NO_MEMORY ()); retval->replace (unk); return retval; }
ACE_Array_Base<DynamicAny::DynAny_var> TAO_DynStruct_i::da_members_ [private] |
Each component is also a DynAny.
Definition at line 107 of file DynStruct_i.h.