summaryrefslogtreecommitdiff
path: root/TAO/tao/DynamicAny/DynUnion_i.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'TAO/tao/DynamicAny/DynUnion_i.cpp')
-rw-r--r--TAO/tao/DynamicAny/DynUnion_i.cpp2554
1 files changed, 0 insertions, 2554 deletions
diff --git a/TAO/tao/DynamicAny/DynUnion_i.cpp b/TAO/tao/DynamicAny/DynUnion_i.cpp
deleted file mode 100644
index b0300f693b4..00000000000
--- a/TAO/tao/DynamicAny/DynUnion_i.cpp
+++ /dev/null
@@ -1,2554 +0,0 @@
-/* -*- C++ -*- */
-// $Id$
-
-
-#include "DynUnion_i.h"
-
-#include "DynAnyFactory.h"
-#include "tao/Marshal.h"
-
-ACE_RCSID(DynamicAny, DynUnion_i, "$Id$")
-
-#if defined (ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION)
-template class DU_Extractor<CORBA::Short>;
-template class DU_Extractor<CORBA::Long>;
-template class DU_Extractor<CORBA::UShort>;
-template class DU_Extractor<CORBA::ULong>;
-
-// For platforms without native 64-bit ints . . .
-#if !defined (ACE_LACKS_LONGLONG_T)
-template class DU_Extractor<CORBA::LongLong>;
-#endif /* ACE_LACKS_LONGLONG_T */
-
-template class DU_Extractor<CORBA::ULongLong>;
-#elif defined (ACE_HAS_TEMPLATE_INSTANTIATION_PRAGMA)
-#pragma instantiate DU_Extractor<CORBA::Short>
-#pragma instantiate DU_Extractor<CORBA::Long>
-#pragma instantiate DU_Extractor<CORBA::UShort>
-#pragma instantiate DU_Extractor<CORBA::ULong>
-
-// For platforms without native 64-bit ints . . .
-#if !defined (ACE_LACKS_LONGLONG_T)
-#pragma instantiate DU_Extractor<CORBA::LongLong>
-#endif /* ACE_LACKS_LONGLONG_T */
-
-#pragma instantiate DU_Extractor<CORBA::ULongLong>
-#endif /* ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION */
-
-// Constructors and destructor
-
-TAO_DynUnion_i::TAO_DynUnion_i (void)
-{
-}
-
-TAO_DynUnion_i::~TAO_DynUnion_i (void)
-{
-}
-
-void
-TAO_DynUnion_i::init (const CORBA_Any& any,
- CORBA::Environment &ACE_TRY_ENV)
-{
- CORBA::TypeCode_var tc = any.type ();
- int tk = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (tk != CORBA::tk_union)
- ACE_THROW (DynamicAny::DynAnyFactory::InconsistentTypeCode ());
-
- // Initialize the typecode holder
- this->type_ = any.type ();
-
- this->set_from_any (any,
- ACE_TRY_ENV);
- ACE_CHECK;
-}
-
-void
-TAO_DynUnion_i::init (CORBA_TypeCode_ptr tc,
- CORBA::Environment &ACE_TRY_ENV)
-{
- int tk = TAO_DynAnyFactory::unalias (tc,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (tk != CORBA::tk_union)
- ACE_THROW (DynamicAny::DynAnyFactory::InconsistentTypeCode ());
-
- // Initialize the typecode holder
- this->type_ =
- CORBA::TypeCode::_duplicate (tc);
-
- CORBA::TypeCode_var disc_tc =
- tc->discriminator_type (ACE_TRY_ENV);
- ACE_CHECK;
-
- // Get a typecode into the discriminator holder.
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (disc_tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- // To be filled in by from_any() or assign().
- this->member_ = 0;
-}
-
-// ****************************************************************
-
-TAO_DynUnion_i *
-TAO_DynUnion_i::_narrow (CORBA::Object_ptr obj,
- CORBA::Environment &)
-{
- if (CORBA::is_nil (obj))
- return 0;
-
- return ACE_reinterpret_cast (TAO_DynUnion_i*,
- obj->_tao_QueryInterface (ACE_reinterpret_cast(ptr_arith_t,
- &TAO_DynUnion_i::_narrow))
- );
-}
-
-void*
-TAO_DynUnion_i::_tao_QueryInterface (ptr_arith_t type)
-{
- ptr_arith_t mytype =
- ACE_reinterpret_cast(ptr_arith_t,
- &TAO_DynUnion_i::_narrow);
- if (type == mytype)
- {
- this->_add_ref ();
- return this;
- }
- return this->ACE_NESTED_CLASS (DynamicAny, DynAny::_tao_QueryInterface) (type);
-}
-
-// Private functions
-
-// Some specialized instantiations of the template functor defined in
-// DynUnion_i_T.cpp.
-
-CORBA::Boolean
-TAO_DynUnion_i::Boolean_extractor::check_match (const CORBA_Any &inside_any,
- const CORBA_Any &outside_any)
-{
- CORBA::Any::to_boolean member_struct (this->member_index_);
- CORBA::Any::to_boolean arg_struct (this->arg_index_);
-
- inside_any >>= member_struct;
- outside_any >>= arg_struct;
-
- return member_struct.ref_ == arg_struct.ref_;
-}
-
-CORBA::Boolean
-TAO_DynUnion_i::Char_extractor::check_match (const CORBA_Any &inside_any,
- const CORBA_Any &outside_any)
-{
- CORBA::Any::to_char member_struct (this->member_index_);
- CORBA::Any::to_char arg_struct (this->arg_index_);
-
- inside_any >>= member_struct;
- outside_any >>= arg_struct;
-
- return member_struct.ref_ == arg_struct.ref_;
-}
-
-CORBA::Boolean
-TAO_DynUnion_i::WChar_extractor::check_match (const CORBA_Any &inside_any,
- const CORBA_Any &outside_any)
-{
- CORBA::Any::to_wchar member_struct (this->member_index_);
- CORBA::Any::to_wchar arg_struct (this->arg_index_);
-
- inside_any >>= member_struct;
- outside_any >>= arg_struct;
-
- return member_struct.ref_ == arg_struct.ref_;
-}
-
-CORBA::Boolean
-TAO_DynUnion_i::Enum_extractor::check_match (const CORBA_Any &inside_any,
- const CORBA_Any &outside_any)
-{
- // Get the CDR stream of one argument...
- ACE_Message_Block *mb = inside_any._tao_get_cdr ();
-
- TAO_InputCDR inside_cdr (mb,
- inside_any._tao_byte_order ());
-
- inside_cdr.read_ulong (this->member_index_);
-
- // And of the other...
- mb = outside_any._tao_get_cdr ();
-
- TAO_InputCDR outside_cdr (mb,
- outside_any._tao_byte_order ());
-
- outside_cdr.read_ulong (this->arg_index_);
-
- return this->member_index_ == this->arg_index_;
-}
-
-// Functor factory.
-DU_Extractor_base*
-TAO_DynUnion_i::get_extractor (CORBA::TCKind kind,
- CORBA::Environment& ACE_TRY_ENV)
-{
- DU_Extractor_base* retval;
-
- switch (kind)
- {
- case CORBA::tk_short:
- ACE_NEW_THROW_EX (retval,
- DU_Extractor<CORBA::Short>,
- CORBA::NO_MEMORY ());
- ACE_CHECK_RETURN (0);
- return retval;
- case CORBA::tk_long:
- ACE_NEW_THROW_EX (retval,
- DU_Extractor<CORBA::Long>,
- CORBA::NO_MEMORY ());
- ACE_CHECK_RETURN (0);
- return retval;
- case CORBA::tk_ushort:
- ACE_NEW_THROW_EX (retval,
- DU_Extractor<CORBA::UShort>,
- CORBA::NO_MEMORY ());
- ACE_CHECK_RETURN (0);
- return retval;
- case CORBA::tk_ulong:
- ACE_NEW_THROW_EX (retval,
- DU_Extractor<CORBA::ULong>,
- CORBA::NO_MEMORY ());
- ACE_CHECK_RETURN (0);
- return retval;
- case CORBA::tk_boolean:
- ACE_NEW_THROW_EX (retval,
- Boolean_extractor,
- CORBA::NO_MEMORY ());
- ACE_CHECK_RETURN (0);
- return retval;
- case CORBA::tk_char:
- ACE_NEW_THROW_EX (retval,
- Char_extractor,
- CORBA::NO_MEMORY ());
- ACE_CHECK_RETURN (0);
- return retval;
-
- // For platforms without native 64-bit ints . . .
-#if !defined (ACE_LACKS_LONGLONG_T)
- case CORBA::tk_longlong:
- ACE_NEW_THROW_EX (retval,
- DU_Extractor<CORBA::LongLong>,
- CORBA::NO_MEMORY ());
-
- ACE_CHECK_RETURN (0);
- return retval;
-#endif /* ACE_LACKS_LONGLONG_T */
-
- case CORBA::tk_ulonglong:
- ACE_NEW_THROW_EX (retval,
- DU_Extractor<CORBA::ULongLong>,
- CORBA::NO_MEMORY ());
- ACE_CHECK_RETURN (0);
- return retval;
- case CORBA::tk_wchar:
- ACE_NEW_THROW_EX (retval,
- WChar_extractor,
- CORBA::NO_MEMORY ());
- ACE_CHECK_RETURN (0);
- return retval;
- case CORBA::tk_enum:
- ACE_NEW_THROW_EX (retval,
- Enum_extractor,
- CORBA::NO_MEMORY ());
- ACE_CHECK_RETURN (0);
- return retval;
- default:
- return 0;
- }
-}
-
-// This code is common to from_any and the constructor taking an Any
-// argument.
-void
-TAO_DynUnion_i::set_from_any (const CORBA_Any& any,
- CORBA::Environment &ACE_TRY_ENV)
-{
- // Get the CDR stream of the argument.
- ACE_Message_Block* mb = any._tao_get_cdr ();
-
- TAO_InputCDR cdr (mb,
- any._tao_byte_order ());
-
- CORBA::TypeCode_var tc = any.type ();
-
- CORBA_TypeCode_var disc_tc = tc->discriminator_type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any disc_any (disc_tc.in (),
- 0,
- cdr.byte_order (),
- cdr.start ());
-
- if (!CORBA::is_nil (this->discriminator_.in ()))
- {
- this->discriminator_->destroy (ACE_TRY_ENV);
- ACE_CHECK;
- }
-
- // Set the discriminator holder.
- this->discriminator_ = TAO_DynAnyFactory::make_dyn_any (disc_any,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- // Move to the next field in the CDR stream.
- (void) TAO_Marshal_Object::perform_skip (disc_tc.in (),
- &cdr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::ULong count = tc->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::ULong i;
- CORBA::Long default_index = -1;
-
- CORBA::TCKind discriminator_kind = disc_tc->kind (ACE_TRY_ENV);
- ACE_CHECK;
-
- DU_Extractor_base* functor =
- this->get_extractor (discriminator_kind,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TypeCode_var label_tc;
-
- // Get the index.
- for (i = 0; i < count; i++)
- {
- CORBA_Any label_any = *tc->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- label_tc = label_any.type ();
-
- CORBA::TCKind label_kind = label_tc->kind (ACE_TRY_ENV);
- ACE_CHECK;
-
- // If there is a default index, note the value but don't call
- // check_match.
- if (label_kind == CORBA::tk_octet)
- {
- default_index = i;
- continue;
- }
- // Check if values match.
- else if (functor->check_match (disc_any,
- label_any))
- {
- this->current_index_ = i;
- break;
- }
- }
-
- delete functor;
-
- if (i == count && default_index == -1)
- {
- ACE_THROW (DynamicAny::DynAny::TypeMismatch ());
- }
- else
- {
- if (i == count && default_index != -1)
- {
- this->current_index_ = default_index;
- }
-
- CORBA::TypeCode_var member_tc =
- tc->member_type (this->current_index_,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any member_any (member_tc.in (),
- 0,
- cdr.byte_order (),
- cdr.start ());
-
- if (!CORBA::is_nil (this->member_.in ()))
- {
- this->member_->destroy (ACE_TRY_ENV);
- ACE_CHECK;
- }
-
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (member_any,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
-}
-
-// ****************************************************************
-
-DynamicAny::DynAny_ptr
-TAO_DynUnion_i::get_discriminator (
- CORBA::Environment &
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException
- ))
-{
- return DynamicAny::DynAny::_duplicate (this->discriminator_.in ());
-}
-
-void
-TAO_DynUnion_i::set_discriminator (
- DynamicAny::DynAny_ptr,
- CORBA::Environment &ACE_TRY_ENV
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch
- ))
-{
- ACE_THROW (CORBA::NO_IMPLEMENT ());
-}
-
-void
-TAO_DynUnion_i::set_to_default_member (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch
- ))
-{
- ACE_THROW (CORBA::NO_IMPLEMENT ());
-}
-
-void
-TAO_DynUnion_i::set_to_no_active_member (CORBA::Environment& ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch
- ))
-{
- ACE_THROW (CORBA::NO_IMPLEMENT ());
-}
-
-CORBA::Boolean
-TAO_DynUnion_i::has_no_active_member (
- CORBA::Environment &ACE_TRY_ENV
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException
- ))
-{
- ACE_THROW_RETURN (CORBA::NO_IMPLEMENT (), 0);
-}
-
-CORBA::TCKind
-TAO_DynUnion_i::discriminator_kind (CORBA::Environment& ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException
- ))
-{
- CORBA_TypeCode_var tc = this->type_->discriminator_type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (CORBA::tk_null);
-
- CORBA::TCKind retval = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (CORBA::tk_null);
-
- return retval;
-}
-
-DynamicAny::DynAny_ptr
-TAO_DynUnion_i::member (CORBA::Environment &)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- return DynamicAny::DynAny::_duplicate (this->member_.in ());
-}
-
-char*
-TAO_DynUnion_i::member_name (CORBA::Environment& ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- const char *retval = this->type_->member_name (this->current_index_,
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- return CORBA::string_dup (retval);
-}
-
-CORBA::TCKind
-TAO_DynUnion_i::member_kind (CORBA::Environment& ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var tc = this->type_->member_type (this->current_index_,
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (CORBA::tk_null);
-
- CORBA::TCKind retval = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (CORBA::tk_null);
-
- return retval;
-}
-
-// ****************************************************************
-
-CORBA::TypeCode_ptr
-TAO_DynUnion_i::type (CORBA::Environment &)
- ACE_THROW_SPEC ((
- CORBA::SystemException
- ))
-{
- return CORBA::TypeCode::_duplicate (this->type_.in ());
-}
-
-void
-TAO_DynUnion_i::assign (DynamicAny::DynAny_ptr dyn_any,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch
- ))
-{
- // *dyn_any->to_any raises Invalid if arg is bad.
- CORBA_TypeCode_ptr tc = dyn_any->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::Boolean equal = this->type_->equal (tc,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (equal)
- {
- CORBA_Any_ptr any_ptr = dyn_any->to_any (ACE_TRY_ENV);
- ACE_CHECK;
-
- this->from_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- ACE_THROW (DynamicAny::DynAny::TypeMismatch ());
- }
-}
-
-void
-TAO_DynUnion_i::from_any (const CORBA_Any& any,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::TypeCode_var tc = any.type ();
- CORBA::Boolean equal = this->type_.in ()->equal (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (equal)
- {
- this->set_from_any (any,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- ACE_THROW (DynamicAny::DynAny::TypeMismatch ());
- }
-}
-
-CORBA::Any_ptr
-TAO_DynUnion_i::to_any (CORBA::Environment& ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException
- ))
-{
- // Both Dynanys must have been initialied.
- if (this->member_.in () == 0
- || this->discriminator_.in () == 0)
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-
- TAO_OutputCDR out_cdr;
-
- // Add the discriminator to the CDR stream.
-
- CORBA_TypeCode_ptr disc_tc =
- this->discriminator_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- CORBA_Any_var disc_any =
- this->discriminator_->to_any (ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- ACE_Message_Block *disc_mb =
- disc_any->_tao_get_cdr ();
-
- TAO_InputCDR disc_cdr (disc_mb,
- disc_any->_tao_byte_order ());
-
- (void) TAO_Marshal_Object::perform_append (disc_tc,
- &disc_cdr,
- &out_cdr,
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- // Add the member to the CDR stream.
-
- CORBA_TypeCode_ptr member_tc =
- this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- CORBA_Any_var member_any =
- this->member_->to_any (ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- ACE_Message_Block *member_mb =
- member_any->_tao_get_cdr ();
-
- TAO_InputCDR member_cdr (member_mb,
- member_any->_tao_byte_order ());
-
- (void) TAO_Marshal_Object::perform_append (member_tc,
- &member_cdr,
- &out_cdr,
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- // Make the Any.
- TAO_InputCDR in_cdr (out_cdr);
-
- CORBA_Any *retval;
- CORBA_TypeCode_ptr tc = this->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- ACE_NEW_THROW_EX (retval,
- CORBA_Any (tc,
- 0,
- in_cdr.byte_order (),
- in_cdr.start ()),
- CORBA::NO_MEMORY ());
- ACE_CHECK_RETURN (0);
-
- return retval;
-}
-
-CORBA::Boolean
-TAO_DynUnion_i::equal (
- DynamicAny::DynAny_ptr,
- CORBA::Environment &ACE_TRY_ENV
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException
- ))
-{
- ACE_THROW_RETURN (CORBA::NO_IMPLEMENT (), 0);
-}
-
-void
-TAO_DynUnion_i::destroy (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException
- ))
-{
- // Free the two DynAnys.
- this->member_->destroy (ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_->destroy (ACE_TRY_ENV);
- ACE_CHECK;
-
- // Free the top level
- delete this;
-}
-
-DynamicAny::DynAny_ptr
-TAO_DynUnion_i::copy (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException
- ))
-{
- CORBA_Any_ptr a = this->to_any (ACE_TRY_ENV);
- ACE_CHECK_RETURN (DynamicAny::DynAny::_nil ());
-
- DynamicAny::DynAny_ptr retval =
- TAO_DynAnyFactory::make_dyn_any (*a,
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (DynamicAny::DynAny::_nil ());
-
- return retval;
-}
-
-// ****************************************************************
-
-void
-TAO_DynUnion_i::insert_boolean (CORBA::Boolean value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_boolean)
- {
- this->member_->insert_boolean (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_boolean)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_boolean (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_octet (CORBA::Octet value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_octet)
- {
- this->member_->insert_octet (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_octet)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_octet (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_char (CORBA::Char value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_char)
- {
- this->member_->insert_char (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_char)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_char (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_short (CORBA::Short value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_short)
- {
- this->member_->insert_short (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_short)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_short (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_long (CORBA::Long value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_long)
- {
- this->member_->insert_long (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_long)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_long (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_ushort (CORBA::UShort value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_ushort)
- {
- this->member_->insert_ushort (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_ushort)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_ushort (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_ulong (CORBA::ULong value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_ulong)
- {
- this->member_->insert_ulong (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_ulong)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_ulong (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_float (CORBA::Float value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_float)
- {
- this->member_->insert_float (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_float)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_float (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_double (CORBA::Double value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_double)
- {
- this->member_->insert_double (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_double)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_double (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_string (const char* value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_string)
- {
- this->member_->insert_string (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_string)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_string (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_reference (CORBA::Object_ptr value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_objref)
- {
- this->member_->insert_reference (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_objref)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_reference (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_typecode (CORBA::TypeCode_ptr value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_TypeCode)
- {
- this->member_->insert_typecode (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_TypeCode)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_typecode (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_longlong (CORBA::LongLong value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_longlong)
- {
- this->member_->insert_longlong (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_longlong)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_longlong (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_ulonglong (CORBA::ULongLong value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_ulonglong)
- {
- this->member_->insert_ulonglong (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_ulonglong)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_ulonglong (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_longdouble (
- CORBA::LongDouble,
- CORBA::Environment &ACE_TRY_ENV
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- ACE_THROW (CORBA::NO_IMPLEMENT ());
-}
-
-void
-TAO_DynUnion_i::insert_wchar (CORBA::WChar value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_wchar)
- {
- this->member_->insert_wchar (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_wchar)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_wchar (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_wstring (
- const CORBA::WChar *,
- CORBA::Environment &ACE_TRY_ENV
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- ACE_THROW (CORBA::NO_IMPLEMENT ());
-}
-
-void
-TAO_DynUnion_i::insert_any (const CORBA::Any& value,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA_TypeCode_var type = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (type.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (kind == CORBA::tk_any)
- {
- this->member_->insert_any (value,
- ACE_TRY_ENV);
- ACE_CHECK;
- }
- else
- {
- CORBA::ULong count =
- this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK;
-
- for (CORBA::ULong i = 0;
- i < count;
- i++)
- {
- CORBA::TypeCode_var tc =
- this->type_->member_type (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA::TCKind try_kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- if (try_kind == CORBA::tk_any)
- {
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_->insert_any (value,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- CORBA_Any_ptr any_ptr = this->type_->member_label (i,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->discriminator_ =
- TAO_DynAnyFactory::make_dyn_any (*any_ptr,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->current_index_ = i;
- return;
- }
- }
-
- ACE_THROW (DynamicAny::DynAny::InvalidValue ());
- }
-}
-
-void
-TAO_DynUnion_i::insert_dyn_any (
- DynamicAny::DynAny_ptr,
- CORBA::Environment &ACE_TRY_ENV
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- ACE_THROW (CORBA::NO_IMPLEMENT ());
-}
-
-#ifdef TAO_HAS_VALUETYPE
-void
-TAO_DynUnion_i::insert_val (
- CORBA::ValueBase_ptr,
- CORBA::Environment &ACE_TRY_ENV
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- ACE_THROW (CORBA::NO_IMPLEMENT ());
-}
-#endif /* TAO_HAS_VALUETYPE */
-
-// ****************************************************************
-
-CORBA::Boolean
-TAO_DynUnion_i::get_boolean (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::Boolean retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_boolean))
- {
- retval = this->member_->get_boolean (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::Octet
-TAO_DynUnion_i::get_octet (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::Octet retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_octet))
- {
- retval = this->member_->get_octet (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::Char
-TAO_DynUnion_i::get_char (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::Char retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_char))
- {
- retval = this->member_->get_char (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::Short
-TAO_DynUnion_i::get_short (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::Short retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_short))
- {
- retval = this->member_->get_short (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::Long
-TAO_DynUnion_i::get_long (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::Long retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_long))
- {
- retval = this->member_->get_long (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::UShort
-TAO_DynUnion_i::get_ushort(CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::UShort retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_ushort))
- {
- retval = this->member_->get_ushort (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::ULong
-TAO_DynUnion_i::get_ulong (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::ULong retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_ulong))
- {
- retval = this->member_->get_ulong (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::Float
-TAO_DynUnion_i::get_float (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::Float retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_float))
- {
- retval = this->member_->get_float (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::Double
-TAO_DynUnion_i::get_double (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::Double retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_double))
- {
- retval = this->member_->get_double (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-char *
-TAO_DynUnion_i::get_string (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- char * retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_string))
- {
- retval = this->member_->get_string (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::TypeCode_ptr
-TAO_DynUnion_i::get_typecode (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::TypeCode_ptr retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_TypeCode))
- {
- retval = this->member_->get_typecode (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::Object_ptr
-TAO_DynUnion_i::get_reference (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::Object_ptr retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_objref))
- {
- retval = this->member_->get_reference (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::LongLong
-TAO_DynUnion_i::get_longlong (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
-#if defined (ACE_LACKS_LONGLONG_T)
- CORBA::LongLong retval = {0, 0};
-#else /* ! ACE_LACKS_LONGLONG_T */
- CORBA::LongLong retval = 0;
-#endif /* ! ACE_LACKS_LONGLONG_T */
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_longlong))
- {
- retval = this->member_->get_longlong (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- retval);
- }
-}
-
-CORBA::ULongLong
-TAO_DynUnion_i::get_ulonglong (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::ULongLong retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_ulonglong))
- {
- retval = this->member_->get_ulonglong (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::LongDouble
-TAO_DynUnion_i::get_longdouble (
- CORBA::Environment &ACE_TRY_ENV
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::LongDouble ret = ACE_CDR_LONG_DOUBLE_INITIALIZER;
- ACE_UNUSED_ARG (ret);
- ACE_THROW_RETURN (CORBA::NO_IMPLEMENT (), ret);
-}
-
-CORBA::WChar
-TAO_DynUnion_i::get_wchar (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::WChar retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_wchar))
- {
- retval = this->member_->get_wchar (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-CORBA::WChar *
-TAO_DynUnion_i::get_wstring (
- CORBA::Environment &ACE_TRY_ENV
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- ACE_THROW_RETURN (CORBA::NO_IMPLEMENT (), 0);
-}
-
-CORBA::Any_ptr
-TAO_DynUnion_i::get_any (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- CORBA::Any_ptr retval = 0;
-
- CORBA_TypeCode_var tc = this->member_->type (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- CORBA::TCKind kind = TAO_DynAnyFactory::unalias (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- if (this->member_.in () && (kind == CORBA::tk_any))
- {
- retval = this->member_->get_any (ACE_TRY_ENV);
- ACE_CHECK_RETURN (retval);
-
- return retval;
- }
- else
- {
- ACE_THROW_RETURN (DynamicAny::DynAny::TypeMismatch (),
- 0);
- }
-}
-
-DynamicAny::DynAny_ptr
-TAO_DynUnion_i::get_dyn_any (
- CORBA::Environment &ACE_TRY_ENV
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- ACE_THROW_RETURN (CORBA::NO_IMPLEMENT (), DynamicAny::DynAny::_nil ());
-}
-
-#ifdef TAO_HAS_VALUETYPE
-CORBA::ValueBase_ptr
-TAO_DynUnion_i::get_val (
- CORBA::Environment &ACE_TRY_ENV
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch,
- DynamicAny::DynAny::InvalidValue
- ))
-{
- ACE_THROW_RETURN (CORBA::NO_IMPLEMENT (), 0);
-}
-#endif /* TAO_HAS_VALUETYPE */
-
-// ****************************************************************
-
-CORBA::Boolean
-TAO_DynUnion_i::seek (CORBA::Long slot,
- CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException
- ))
-{
- CORBA::ULong count = this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- if (slot < 0 || slot >= (CORBA::Long) count)
- {
- return 0;
- }
-
- this->current_index_ = slot;
-
- if (!CORBA::is_nil (this->member_.in ()))
- {
- this->member_->destroy (ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
- }
-
- CORBA_TypeCode_var tc = this->type_->member_type (this->current_index_,
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- return 1;
-}
-
-void
-TAO_DynUnion_i::rewind (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException
- ))
-{
- if (this->current_index_ == 0)
- return;
-
- this->current_index_ = 0;
-
- if (!CORBA::is_nil (this->member_.in ()))
- {
- this->member_->destroy (ACE_TRY_ENV);
- ACE_CHECK;
- }
-
- CORBA_TypeCode_var tc = this->type_->member_type (this->current_index_,
- ACE_TRY_ENV);
- ACE_CHECK;
-
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK;
-}
-
-CORBA::Boolean
-TAO_DynUnion_i::next (CORBA::Environment &ACE_TRY_ENV)
- ACE_THROW_SPEC ((
- CORBA::SystemException
- ))
-{
- CORBA::ULong count = this->type_->member_count (ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- if (this->current_index_ + 1 == count)
- {
- return 0;
- }
-
- ++this->current_index_;
-
- if (!CORBA::is_nil (this->member_.in ()))
- {
- this->member_->destroy (ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
- }
-
- CORBA_TypeCode_var tc = this->type_->member_type (this->current_index_,
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- this->member_ =
- TAO_DynAnyFactory::make_dyn_any (tc.in (),
- ACE_TRY_ENV);
- ACE_CHECK_RETURN (0);
-
- return 1;
-}
-
-CORBA::ULong
-TAO_DynUnion_i::component_count (
- CORBA::Environment &ACE_TRY_ENV
- )
- ACE_THROW_SPEC ((
- CORBA::SystemException
- ))
-{
- ACE_THROW_RETURN (CORBA::NO_IMPLEMENT (), 0);
-}
-
-DynamicAny::DynAny_ptr
-TAO_DynUnion_i::current_component (CORBA::Environment &)
- ACE_THROW_SPEC ((
- CORBA::SystemException,
- DynamicAny::DynAny::TypeMismatch
- ))
-{
- return DynamicAny::DynAny::_duplicate (this->member_.in ());
-}