diff options
Diffstat (limited to 'trunk/TAO/tests/Stack_Recursion/Client_Task.cpp')
-rw-r--r-- | trunk/TAO/tests/Stack_Recursion/Client_Task.cpp | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/trunk/TAO/tests/Stack_Recursion/Client_Task.cpp b/trunk/TAO/tests/Stack_Recursion/Client_Task.cpp new file mode 100644 index 00000000000..58747bad1e4 --- /dev/null +++ b/trunk/TAO/tests/Stack_Recursion/Client_Task.cpp @@ -0,0 +1,72 @@ +// +// $Id$ +// + +#include "Client_Task.h" + +ACE_RCSID(Stack_Recursion, + Client_Task, + "$Id$") + +Client_Task::Client_Task (Test::Sender_ptr sender, + CORBA::Long event_count, + CORBA::ULong event_size, + ACE_Thread_Manager *thr_mgr) + : ACE_Task_Base (thr_mgr) + , sender_ (Test::Sender::_duplicate (sender)) + , event_count_ (event_count) + , event_size_ (event_size) +{ +} + +int +Client_Task::svc (void) +{ + ACE_DEBUG ((LM_DEBUG, "(%P|%t) Starting client task\n")); + + ACE_DECLARE_NEW_CORBA_ENV; + ACE_TRY + { + this->validate_connections (ACE_ENV_SINGLE_ARG_PARAMETER); + ACE_TRY_CHECK; + + for (int i = 0; i != this->event_count_; ++i) + { +#if 0 + if (i%100 == 0) + ACE_DEBUG ((LM_DEBUG, + "(%P|%t) In iteration [%d] ....\n", + i)); +#endif /*if 0*/ + Test::Payload_var pl = new Test::Payload; + Test::Payload_out payload (pl.out ()); + this->sender_->get_data (this->event_size_, + payload + ACE_ENV_ARG_PARAMETER); + ACE_TRY_CHECK; + } + } + ACE_CATCHANY + { + return -1; + } + ACE_ENDTRY; + ACE_DEBUG ((LM_DEBUG, "(%P|%t) Client task finished\n")); + return 0; +} + + +void +Client_Task::validate_connections (ACE_ENV_SINGLE_ARG_DECL) +{ + for (int i = 0 ; i != 100; i++) + { + ACE_TRY + { + this->sender_->ping (ACE_ENV_SINGLE_ARG_PARAMETER); + ACE_TRY_CHECK; + + } + ACE_CATCHANY {} ACE_ENDTRY; + } +} |