// $Id$ // ============================================================================ // // = LIBRARY // TAO/tests/Param_Test // // = FILENAME // bd_long_seq.cpp // // = DESCRIPTION // tests bounded long sequences // // = AUTHORS // Aniruddha Gokhale // // ============================================================================ #include "helper.h" #include "bd_long_seq.h" ACE_RCSID(Param_Test, bd_long_seq, "$Id$") // ************************************************************************ // Test_Bounded_Long_Sequence // ************************************************************************ Test_Bounded_Long_Sequence::Test_Bounded_Long_Sequence (void) : opname_ (CORBA::string_dup ("test_bounded_long_sequence")), in_ (new Param_Test::Bounded_Long_Seq), inout_ (new Param_Test::Bounded_Long_Seq), out_ (new Param_Test::Bounded_Long_Seq), ret_ (new Param_Test::Bounded_Long_Seq) { } Test_Bounded_Long_Sequence::~Test_Bounded_Long_Sequence (void) { CORBA::string_free (this->opname_); this->opname_ = 0; } const char * Test_Bounded_Long_Sequence::opname (void) const { return this->opname_; } void Test_Bounded_Long_Sequence::dii_req_invoke (CORBA::Request *req ACE_ENV_ARG_DECL) { req->add_in_arg ("s1") <<= this->in_.in (); req->add_inout_arg ("s2") <<= this->inout_.in (); req->add_out_arg ("s3") <<= this->out_.in (); req->set_return_type (Param_Test::_tc_Bounded_Long_Seq); req->invoke (ACE_ENV_SINGLE_ARG_PARAMETER); ACE_CHECK; const Param_Test::Bounded_Long_Seq *tmp; req->return_value () >>= tmp; this->ret_ = new Param_Test::Bounded_Long_Seq (*tmp); CORBA::NamedValue_ptr arg2 = req->arguments ()->item (1 ACE_ENV_ARG_PARAMETER); ACE_CHECK; *arg2->value () >>= tmp; this->inout_ = new Param_Test::Bounded_Long_Seq (*tmp); CORBA::NamedValue_ptr arg3 = req->arguments ()->item (2 ACE_ENV_ARG_PARAMETER); ACE_CHECK; *arg3->value () >>= tmp; this->out_ = new Param_Test::Bounded_Long_Seq (*tmp); } int Test_Bounded_Long_Sequence::init_parameters (Param_Test_ptr ACE_ENV_ARG_DECL_NOT_USED) { // get some sequence length (32 in this case) CORBA::ULong len = this->in_->maximum (); // set the length of the sequence this->in_->length (len); this->inout_->length (len); // now set each individual element for (CORBA::ULong i=0; i < this->in_->maximum (); i++) { this->in_[i] = i; this->inout_[i] = i+1; // different from in_ } this->inout_->length (0); this->out_->length (0); this->ret_->length (0); return 0; } int Test_Bounded_Long_Sequence::reset_parameters (void) { this->inout_ = new Param_Test::Bounded_Long_Seq; // delete the previous ones this->out_ = new Param_Test::Bounded_Long_Seq; this->ret_ = new Param_Test::Bounded_Long_Seq; this->inout_->length (0); this->out_->length (0); this->ret_->length (0); return 0; } int Test_Bounded_Long_Sequence::run_sii_test (Param_Test_ptr objref ACE_ENV_ARG_DECL) { ACE_TRY { Param_Test::Bounded_Long_Seq_out out (this->out_.out ()); this->ret_ = objref->test_bounded_long_sequence (this->in_.in (), this->inout_.inout (), out ACE_ENV_ARG_PARAMETER); ACE_TRY_CHECK; return 0; } ACE_CATCHANY { ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION, "Test_Bounded_Long_Sequence::run_sii_test\n"); } ACE_ENDTRY; return -1; } CORBA::Boolean Test_Bounded_Long_Sequence::check_validity (void) { CORBA::Boolean flag = 0; if ((this->in_->length () == this->inout_->length ()) && (this->in_->length () == this->out_->length ()) && (this->in_->length () == this->ret_->length ())) { flag = 1; // assume all are equal // lengths are same. Now compare the contents for (CORBA::ULong i=0; i < this->in_->length () && flag; i++) { if (this->in_[i] != this->inout_[i] || this->in_[i] != this->out_[i] || this->in_[i] != this->ret_[i]) // not equal flag = 0; } } return flag; } CORBA::Boolean Test_Bounded_Long_Sequence::check_validity (CORBA::Request_ptr req) { ACE_UNUSED_ARG (req); return this->check_validity (); } void Test_Bounded_Long_Sequence::print_values (void) { CORBA::ULong i; ACE_DEBUG ((LM_DEBUG, "\n*=*=*=*=*=*=*=*=*=*=\n")); for (i=0; this->in_.ptr () && (i < this->in_->length ()); i++) { ACE_DEBUG ((LM_DEBUG, "Element #%d\n" "in : %d\n", i, this->in_[i])); } if (!this->in_.ptr ()) ACE_DEBUG ((LM_DEBUG, "\nin sequence is NUL\n")); ACE_DEBUG ((LM_DEBUG, "\n*=*=*=*=*=*=*=*=*=*=\n")); for (i=0; this->inout_.ptr () && (i < this->inout_->length ()); i++) { ACE_DEBUG ((LM_DEBUG, "Element #%d\n" "in : %d\n", i, this->inout_[i])); } if (!this->inout_.ptr ()) ACE_DEBUG ((LM_DEBUG, "\ninout sequence is NUL\n")); ACE_DEBUG ((LM_DEBUG, "\n*=*=*=*=*=*=*=*=*=*=\n")); for (i=0; this->out_.ptr () && (i < this->out_->length ()); i++) { ACE_DEBUG ((LM_DEBUG, "Element #%d\n" "in : %d\n", i, this->out_[i])); } if (!this->out_.ptr ()) ACE_DEBUG ((LM_DEBUG, "\nout sequence is NUL\n")); ACE_DEBUG ((LM_DEBUG, "\n*=*=*=*=*=*=*=*=*=*=\n")); for (i=0; this->ret_.ptr () && (i < this->ret_->length ()); i++) { ACE_DEBUG ((LM_DEBUG, "Element #%d\n" "in : %d\n", i, this->ret_[i])); } if (!this->ret_.ptr ()) ACE_DEBUG ((LM_DEBUG, "\nin sequence is NUL\n")); ACE_DEBUG ((LM_DEBUG, "\n*=*=*=*=*=*=*=*=*=*=\n")); }