blob: 3153f62e98aa93b88ce88487c2f66efa7964e570 (
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
#include "Monitor_Signal_Handler.h"
ACE_RCSID (LoadBalancer,
Monitor_Signal_Handler,
"$Id$")
TAO_LB_Monitor_Signal_Handler::TAO_LB_Monitor_Signal_Handler (
CORBA::ORB_ptr orb,
PortableServer::POA_ptr poa,
CosLoadBalancing::LoadManager_ptr load_manager,
const PortableGroup::Location & location)
: TAO_LB_Signal_Handler (orb, poa),
load_manager_ (CosLoadBalancing::LoadManager::_duplicate (load_manager)),
location_ (location)
{
}
int
TAO_LB_Monitor_Signal_Handler::perform_cleanup (int signum)
{
ACE_DECLARE_NEW_CORBA_ENV;
ACE_TRY
{
// Deregister the LoadMonitor from the LoadManager in the PULL
// load monitoring case.
if (!CORBA::is_nil (this->load_manager_.in ()))
{
this->load_manager_->remove_load_monitor (this->location_
ACE_ENV_ARG_PARAMETER);
ACE_TRY_CHECK;
}
}
ACE_CATCHANY
{
ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
"Caught exception");
ACE_ERROR_RETURN ((LM_ERROR,
"Problem during LoadMonitor cleanup "
"initiated by signal %d.\n",
signum),
-1);
}
ACE_ENDTRY;
ACE_CHECK_RETURN (-1);
return this->TAO_LB_Signal_Handler::perform_cleanup (signum);
}
|