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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
// $Id$
#include "Foo_i.h"
#include "OrbShutdownTask.h"
Foo_i::Foo_i(unsigned num_clients)
: value_(0),
num_clients_(num_clients),
count_op1_(0),
count_op2_(0),
count_op3_(0),
count_op4_(0),
count_op5_(0)
{
ACE_DEBUG((LM_DEBUG,
"(%P|%t) Number of clients for Foo_i servant: %d\n",
num_clients));
}
Foo_i::~Foo_i()
{
}
void
Foo_i::op1(void)
{
++this->count_op1_;
// Sleep for 10 milliseconds (10,000 microseconds)
//ACE_OS::sleep(ACE_Time_Value(0,10000));
}
void
Foo_i::op2(CORBA::Long value)
{
++this->count_op2_;
this->value_ = value;
}
CORBA::Long
Foo_i::op3(void)
{
++this->count_op3_;
return this->value_;
}
void
Foo_i::op4(CORBA::Long value)
{
++this->count_op4_;
this->value_ = value;
if (this->count_op4_ % 500 == 0)
{
ACE_DEBUG((LM_DEBUG,
"(%P|%t) op4() has been called %d times now. value == %d\n",
this->count_op4_, this->value_));
}
// Sleep for 10 milliseconds (10,000 microseconds)
//ACE_OS::sleep(ACE_Time_Value(0,10000));
}
void
Foo_i::op5(void)
{
++this->count_op5_;
throw FooException();
}
void
Foo_i::done(void)
{
unsigned num_left = --this->num_clients_;
ACE_DEBUG((LM_DEBUG,
"(%P|%t) A client has reported that it is done(). "
"There are %d clients left.\n", num_left));
if (num_left == 0)
{
ACE_DEBUG((LM_DEBUG, "(%P|%t) Stats:\n"
"op1() count: %d\n"
"op2() count: %d\n"
"op3() count: %d\n"
"op4() count: %d\n"
"op5() count: %d\n",
this->count_op1_,
this->count_op2_,
this->count_op3_,
this->count_op4_,
this->count_op5_));
if (TheOrbShutdownTask::instance()->open(0) != 0)
{
ACE_ERROR((LM_ERROR, "(%P|%t)Foo_i::done: "
"failed to create orb shutdown thread.\n"));
}
}
}
|