summaryrefslogtreecommitdiff
path: root/TAO/CIAO/DAnCE/NodeManager/NodeDaemon_Impl.cpp
blob: 1012a9bf4b3828de2488001eaa30cdc13630b58e (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
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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
// $Id$

#include "NodeDaemon_Impl.h"
#include "../NodeApplicationManager/NodeApplicationManager_Impl.h"

// @@ (OO) Method definitions should never use "_WITH_DEFAULTS"
//         versions of emulated exception parameters.  Please remove
//         the "_WITH_DEFAULTS"
CIAO::NodeDaemon_Impl::NodeDaemon_Impl (const char *name,
                                        CORBA::ORB_ptr orb,
                                        PortableServer::POA_ptr poa,
                                        const char * nodapp_loc,
                                        int spawn_delay)
  ACE_THROW_SPEC ((CORBA::SystemException))
  : orb_ (CORBA::ORB::_duplicate (orb)),
    poa_ (PortableServer::POA::_duplicate (poa)),
    name_ (CORBA::string_dup (name)),
    nodeapp_location_ (CORBA::string_dup (nodapp_loc)),
    callback_poa_ (PortableServer::POA::_nil ()),
    spawn_delay_ (spawn_delay),
    manager_ (Deployment::NodeApplicationManager::_nil ())
{
  ACE_TRY
  {
    //create the call back poa for NAM.
    PortableServer::POAManager_var mgr
      = this->poa_->the_POAManager (ACE_ENV_SINGLE_ARG_PARAMETER);
    ACE_TRY_CHECK;

    this->callback_poa_ =
      this->poa_->create_POA ("callback_poa",
                              mgr.in (),
                              0
                              ACE_ENV_ARG_PARAMETER);
    ACE_TRY_CHECK;

  }
  ACE_CATCHANY
  {
    ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
                         "NodeDaemon_Impl::constructor\t\n");
    ACE_RE_THROW;
  }
  ACE_ENDTRY;
}

CIAO::NodeDaemon_Impl::~NodeDaemon_Impl ()
{

}

PortableServer::POA_ptr
CIAO::NodeDaemon_Impl::_default_POA (void)
{
  return PortableServer::POA::_duplicate (this->poa_.in ());
}


char *
CIAO::NodeDaemon_Impl::name (ACE_ENV_SINGLE_ARG_DECL_NOT_USED)
  ACE_THROW_SPEC ((CORBA::SystemException))
{
  return CORBA::string_dup (this->name_.in ());
}

void
CIAO::NodeDaemon_Impl::shutdown (ACE_ENV_SINGLE_ARG_DECL)
  ACE_THROW_SPEC ((CORBA::SystemException))
{
  this->orb_->shutdown (0 ACE_ENV_ARG_PARAMETER);
  ACE_CHECK;
}

void
CIAO::NodeDaemon_Impl::joinDomain (const Deployment::Domain & ,
                                   Deployment::TargetManager_ptr ,
                                   Deployment::Logger_ptr)
  ACE_THROW_SPEC ((CORBA::SystemException))
{
  ACE_THROW (CORBA::NO_IMPLEMENT ());
}

void
CIAO::NodeDaemon_Impl::leaveDomain (ACE_ENV_SINGLE_ARG_DECL)
  ACE_THROW_SPEC ((CORBA::SystemException))
{
  //Implementation undefined.
  ACE_THROW (CORBA::NO_IMPLEMENT ());
}


Deployment::NodeApplicationManager_ptr
CIAO::NodeDaemon_Impl::preparePlan (const Deployment::DeploymentPlan &plan)
  ACE_THROW_SPEC ((CORBA::SystemException,
                   Deployment::StartError,
                   Deployment::PlanError))
{
  // Return cached manager
  ACE_TRY
  {
    if (CORBA::is_nil (this->manager_.in ()))
    {
      //Implementation undefined.
      CIAO::NodeApplicationManager_Impl *app_mgr;
      ACE_NEW_THROW_EX (app_mgr,
                        CIAO::NodeApplicationManager_Impl (this->orb_.in (),
                                                       this->poa_.in ()),
                        CORBA::NO_MEMORY ());
      ACE_TRY_CHECK;

      PortableServer::ServantBase_var safe (app_mgr);

     //@@ Note: after the init call the servant ref count would become 2. so
     //   we can leave the safeservant along and be dead. Also note that I added
      this->manager_ =
            app_mgr->init (this->nodeapp_location_,
                     this->spawn_delay_,
                     plan,
                     this->callback_poa_.in ()
                     ACE_ENV_ARG_PARAMETER);
      ACE_TRY_CHECK;

      // Obtain the Object Reference
      //CORBA::Object_var obj =
      //  this->poa_->servant_to_reference (app_mgr ACE_ENV_ARG_PARAMETER);
      //ACE_TRY_CHECK;

      //this->manager_ =
      //  Deployment::NodeApplicationManager::_narrow (obj.in ());
      if (CORBA::is_nil (this->manager_.in ()))
        {
          ACE_DEBUG ((LM_DEBUG, "NodeDaemon_Impl:preparePlan: NodeApplicationManager ref is nil\n"));
          ACE_THROW (Deployment::StartError ());
        }
    }

    // Duplicate this reference to the caller
    return
      Deployment::NodeApplicationManager::_duplicate (this->manager_.in ());
  }
  ACE_CATCHANY
  {
    ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
                         "NodeDaemon_Impl::preparePlan\t\n");
    ACE_RE_THROW;
  }
  ACE_ENDTRY;
  ACE_CHECK_RETURN (0);
}

void
CIAO::NodeDaemon_Impl::destroyManager (Deployment::NodeApplicationManager_ptr)
  ACE_THROW_SPEC ((CORBA::SystemException, Deployment::StopError))
{
  ACE_TRY
  {
    // Deactivate this object
    PortableServer::ObjectId_var id =
          this->poa_->reference_to_id (this->manager_.in () ACE_ENV_ARG_PARAMETER);
    ACE_TRY_CHECK;

    this->poa_->deactivate_object (id.in () ACE_ENV_ARG_PARAMETER);
    ACE_TRY_CHECK;

    this->manager_ = Deployment::NodeApplicationManager::_nil ();
  }
  ACE_CATCHANY
  {
    ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
                         "NodeDaemon_Impl::destroyManager\t\n");
    ACE_RE_THROW;
  }
  ACE_ENDTRY;
}