summaryrefslogtreecommitdiff
path: root/trunk/TAO/tests/Param_Test/objref_struct.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'trunk/TAO/tests/Param_Test/objref_struct.cpp')
-rw-r--r--trunk/TAO/tests/Param_Test/objref_struct.cpp287
1 files changed, 287 insertions, 0 deletions
diff --git a/trunk/TAO/tests/Param_Test/objref_struct.cpp b/trunk/TAO/tests/Param_Test/objref_struct.cpp
new file mode 100644
index 00000000000..c299f461a8a
--- /dev/null
+++ b/trunk/TAO/tests/Param_Test/objref_struct.cpp
@@ -0,0 +1,287 @@
+// $Id$
+
+// ============================================================================
+//
+// = LIBRARY
+// TAO/tests/Param_Test
+//
+// = FILENAME
+// objref_struct.cpp
+//
+// = DESCRIPTION
+// test structures containing object references.
+//
+// = AUTHORS
+// Aniruddha Gokhale
+//
+// ============================================================================
+
+#include "helper.h"
+#include "objref_struct.h"
+
+ACE_RCSID (Param_Test,
+ objref_struct,
+ "$Id$")
+
+// ************************************************************************
+// Test_Objref_Struct
+// ************************************************************************
+
+Test_Objref_Struct::Test_Objref_Struct (void)
+ : opname_ (CORBA::string_dup ("test_objref_struct")),
+ inout_ (new Param_Test::Objref_Struct),
+ out_ (new Param_Test::Objref_Struct),
+ ret_ (new Param_Test::Objref_Struct)
+{
+}
+
+Test_Objref_Struct::~Test_Objref_Struct (void)
+{
+ CORBA::string_free (this->opname_);
+ this->opname_ = 0;
+ // the other data members will be freed as they are "_var"s and objects
+ // (rather than pointers to objects)
+}
+
+const char *
+Test_Objref_Struct::opname (void) const
+{
+ return this->opname_;
+}
+
+void
+Test_Objref_Struct::dii_req_invoke (CORBA::Request *req
+ ACE_ENV_ARG_DECL)
+{
+ req->add_in_arg ("s1") <<= this->in_;
+ req->add_inout_arg ("s2") <<= this->inout_.in ();
+ req->add_out_arg ("s3") <<= this->out_.in ();
+
+ req->set_return_type (Param_Test::_tc_Objref_Struct);
+
+ req->invoke (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_CHECK;
+
+ Param_Test::Objref_Struct *tmp;
+ req->return_value () >>= tmp;
+ this->ret_ = new Param_Test::Objref_Struct (*tmp);
+
+ CORBA::NamedValue_ptr o2 =
+ req->arguments ()->item (1 ACE_ENV_ARG_PARAMETER);
+ ACE_CHECK;
+ *o2->value () >>= tmp;
+ this->inout_ = new Param_Test::Objref_Struct (*tmp);
+
+ CORBA::NamedValue_ptr o3 =
+ req->arguments ()->item (2 ACE_ENV_ARG_PARAMETER);
+ ACE_CHECK;
+ *o3->value () >>= tmp;
+ this->out_ = new Param_Test::Objref_Struct (*tmp);
+}
+
+int
+Test_Objref_Struct::init_parameters (Param_Test_ptr objref
+ ACE_ENV_ARG_DECL)
+{
+ ACE_TRY
+ {
+ Generator *gen = GENERATOR::instance (); // value generator
+
+ // Set the long member.
+ this->in_.x = gen->gen_long ();
+
+ this->in_.y = objref->make_coffee (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ Coffee::Desc d;
+ d.name = gen->gen_string ();
+
+ this->in_.y->description (d
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ this->inout_->x = 0;
+
+ this->inout_->y = Coffee::_nil ();
+
+ Coffee::Desc dd;
+ dd.name = CORBA::string_dup ("");
+
+ return 0;
+ }
+ ACE_CATCHANY
+ {
+ ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
+ "Test_Objref_Struct::init_parameters\n");
+
+ }
+ ACE_ENDTRY;
+ return -1;
+}
+
+int
+Test_Objref_Struct::reset_parameters (void)
+{
+ this->inout_ = new Param_Test::Objref_Struct; // delete the previous ones
+ this->out_ = new Param_Test::Objref_Struct;
+ this->ret_ = new Param_Test::Objref_Struct;
+
+ this->inout_->x = 0;
+
+ this->inout_->y = Coffee::_nil ();
+
+ Coffee::Desc dd;
+ dd.name = CORBA::string_dup ("");
+
+ return 0;
+}
+
+int
+Test_Objref_Struct::run_sii_test (Param_Test_ptr objref
+ ACE_ENV_ARG_DECL)
+{
+ ACE_TRY
+ {
+ Param_Test::Objref_Struct_out out (this->out_.out ());
+
+ this->ret_ = objref->test_objref_struct (this->in_,
+ this->inout_.inout (),
+ out
+ ACE_ENV_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ return 0;
+ }
+ ACE_CATCHANY
+ {
+ ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
+ "Test_Objref_Struct::run_sii_test\n");
+
+ }
+ ACE_ENDTRY;
+ return -1;
+}
+
+CORBA::Boolean
+Test_Objref_Struct::check_validity (void)
+{
+ if (this->in_.x != this->inout_->x
+ || this->in_.x != this->out_->x
+ || this->in_.x != this->ret_->x)
+ return 0;
+
+ ACE_DECLARE_NEW_CORBA_ENV;
+
+ ACE_TRY
+ {
+ if (CORBA::is_nil (this->in_.y.in ())
+ || CORBA::is_nil (this->out_->y.in ())
+ || CORBA::is_nil (this->ret_->y.in ())
+ || CORBA::is_nil (this->inout_->y.in ()))
+ {
+ return 0;
+ }
+
+ Coffee::Desc_var s_in = this->in_.y->description (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ Coffee::Desc_var s_out = this->out_->y->description (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ Coffee::Desc_var s_inout = this->inout_->y->description (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ Coffee::Desc_var s_ret = this->ret_->y->description (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ if (ACE_OS::strcmp (s_in->name, s_out->name) != 0
+ || ACE_OS::strcmp (s_in->name, s_inout->name) != 0
+ || ACE_OS::strcmp (s_in->name, s_ret->name) != 0 )
+ {
+ return 0;
+ }
+
+ return 1;
+ }
+ ACE_CATCHANY
+ {
+ ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
+ "Test_Objref_Struct::check_validity\n");
+
+ }
+ ACE_ENDTRY;
+ return 0;
+}
+
+CORBA::Boolean
+Test_Objref_Struct::check_validity (CORBA::Request_ptr /*req*/)
+{
+ return this->check_validity ();
+}
+
+void
+Test_Objref_Struct::print_values (void)
+{
+ ACE_DEBUG ((LM_DEBUG,
+ "\n*=*=*=*=*=*=*=*=*=*=\n"
+ "in_.x = %d\n"
+ "inout_.x = %d\n"
+ "out_.x = %d\n"
+ "ret_.x = %d\n",
+ this->in_.x,
+ this->inout_->x,
+ this->out_->x,
+ this->ret_->x ));
+
+ ACE_DECLARE_NEW_CORBA_ENV;
+
+ ACE_TRY
+ {
+ Coffee::Desc_var s_in =
+ this->in_.y->description (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+
+ Coffee::Desc_var s_inout = new Coffee::Desc;
+ Coffee::Desc_var s_out = new Coffee::Desc;
+ Coffee::Desc_var s_ret = new Coffee::Desc;
+ s_inout->name = CORBA::string_dup ("");
+ s_out->name = CORBA::string_dup ("");
+ s_ret->name = CORBA::string_dup ("");
+
+ if (!CORBA::is_nil (this->out_->y.in ()))
+ {
+ s_out = this->out_->y->description (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ }
+
+ if (!CORBA::is_nil (this->inout_->y.in ()))
+ {
+ s_inout = this->inout_->y->description (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ }
+
+ if (!CORBA::is_nil (this->ret_->y.in ()))
+ {
+ s_ret = this->ret_->y->description (ACE_ENV_SINGLE_ARG_PARAMETER);
+ ACE_TRY_CHECK;
+ }
+
+ ACE_DEBUG ((LM_DEBUG,
+ "\n*=*=*=*=*=*=*=*=*=*=\n"
+ "in_ name = %s\n"
+ "inout_ name = %s\n"
+ "out_ name = %s\n"
+ "ret_ name = %s\n",
+ s_in->name.in (),
+ s_inout->name.in (),
+ s_out->name.in (),
+ s_ret->name.in () ));
+ }
+ ACE_CATCHANY
+ {
+ ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
+ "Test_Objref_Struct::print_values\n");
+ }
+ ACE_ENDTRY;
+ ACE_CHECK;
+}