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
|
#include "Passivate.h"
#include "tao/AnyTypeCode/ExceptionA.h"
#include "dance/Logger/Log_Macros.h"
#include "dance/Deployment/Deployment_StartErrorC.h"
#include "dance/DAnCE_DeploymentInterceptorsC.h"
#include "dance/DAnCE_LocalityManagerC.h"
#include "dance/DAnCE_Utility.h"
#include "dance/LocalityManager/Scheduler/Deployment_Event.h"
#include "dance/LocalityManager/Scheduler/Plugin_Manager.h"
namespace DAnCE
{
Passivate_Instance::Passivate_Instance (::Deployment::DeploymentPlan & plan,
::CORBA::ULong instanceRef,
const CORBA::Any &ref,
const char *inst_type,
Event_Future holder)
: Deployment_Event (holder,
plan.instance[instanceRef].name.in (),
inst_type),
Action_Base (holder,
plan.instance[instanceRef].name.in (),
inst_type),
plan_ (plan),
instanceRef_ (instanceRef),
ref_ (ref)
{
}
Passivate_Instance::~Passivate_Instance (void)
{
}
void
Passivate_Instance::invoke_pre_interceptor (Plugin_Manager::INTERCEPTORS::const_iterator &)
{
DANCE_TRACE ("Passivate_Instance::invoke_pre_interceptor");
//no-op
}
void
Passivate_Instance::invoke (::DAnCE::InstanceDeploymentHandler_ptr handler)
{
DANCE_TRACE ("Passivate_Instance::invoke");
DANCE_DEBUG (DANCE_LOG_TRACE,
(LM_TRACE, DLINFO
ACE_TEXT ("Passivate_Instance::invoke - ")
ACE_TEXT ("Invoking passivate_instance on handler for type <%C>\n"),
this->instance_type_.c_str ()));
handler->passivate_instance (this->plan_,
this->instanceRef_,
this->ref_);
DANCE_DEBUG (DANCE_LOG_DETAILED_TRACE,
(LM_TRACE, DLINFO
ACE_TEXT ("Passivate_Instance::invoke - ")
ACE_TEXT ("passivate_instance completed\n")));
}
void
Passivate_Instance::invoke_post_interceptor (Plugin_Manager::INTERCEPTORS::const_iterator &i)
{
DANCE_TRACE ("Passivate_Instance::invoke_post_interceptor");
(*i)->post_passivate (this->plan_,
this->instanceRef_,
this->instance_excep_.in ());
}
void
Passivate_Instance::create_unexpected_exception (const std::string &name,
const std::string &reason)
{
DANCE_TRACE ("Passivate_Instance::create_unexpected_exception");
::Deployment::StopError ex_tmp (name.c_str (),
reason.c_str ());
this->instance_excep_ =
DAnCE::Utility::create_any_from_exception (ex_tmp);
}
void
Passivate_Instance::create_valid_result (Event_Result &)
{
DANCE_TRACE ("Passivate_Instance::create_valid_result");
// no-op
}
}
|