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
|
// $Id$
#include "UDP_i.h"
ACE_RCSID(UDP, UDP_i, "")
// Constructor
UDP_i::UDP_i (void)
{
// no-op
}
// Destructor
UDP_i::~UDP_i (void)
{
// no-op
}
// Set the ORB pointer.
void
UDP_i::orb (CORBA::ORB_ptr o)
{
this->orb_ = CORBA::ORB::_duplicate (o);
}
void
UDP_i::invoke (const char * client_name,
UDP_ptr udpHandler,
CORBA::Long request_id)
{
try
{
ACE_DEBUG ((LM_DEBUG,
"UDP_i::invoke: name = %s request id = %d\n",
client_name,
request_id));
ACE_DEBUG ((LM_DEBUG,
"."));
CORBA::Long last_request_id = 0;
if (request_id_table_.find (client_name,
last_request_id) != -1)
{
if (last_request_id + 1 != request_id)
ACE_DEBUG ((LM_DEBUG,
"UDP_i::invoke: failure on %s expected id = %d, got %d\n",
client_name,
last_request_id+1,
request_id));
}
request_id_table_.rebind (client_name,
request_id);
if (!CORBA::is_nil (udpHandler))
{
udpHandler->invoke (client_name,
UDP::_nil (),
request_id);
}
}
catch (const CORBA::Exception&)
{
ACE_DEBUG ((LM_DEBUG,
"UDP_i::svc: Received exception\n"));
}
}
// Shutdown.
void
UDP_i::shutdown (void)
{
ACE_DEBUG ((LM_DEBUG,
"%s\n",
"UDP_i is shutting down"));
// Instruct the ORB to shutdown.
this->orb_->shutdown ();
}
|