blob: a7874c6e82f32f70f8b34a31c980e18a2db2df29 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
/**
* @file Echo.cpp
*
* @author Carlos O'Ryan <coryan@atdesk.com>
*
*/
#include "Echo.h"
#include "ace/OS_NS_unistd.h"
Echo::Echo(CORBA::ORB_ptr orb,
int abort_counter)
: orb_(CORBA::ORB::_duplicate(orb))
, abort_counter_(abort_counter)
{
}
void
Echo::echo_payload(Test::Payload const &)
{
this->abort_counter_--;
if (this->abort_counter_ == 0)
{
ACE_DEBUG ((LM_DEBUG, "(%P|%t) Echo::echo_payload, sleeping\n"));
// Sleep for 15 seconds, forcing a flow control of some kind.
ACE_OS::sleep(15);
// Run the ORB for a while, to generate a short-lived release of
// the flow control.
ACE_Time_Value tv(0, 10000);
this->orb_->run(tv);
ACE_DEBUG ((LM_DEBUG, "(%P|%t) Echo::echo_payload, aborting\n"));
// Kill the app
ACE_OS::abort();
}
}
|