summaryrefslogtreecommitdiff
path: root/modules/CIAO/DAnCE/DomainApplication/Domain_Application_Impl.cpp
blob: b7178e5400968b068667896e4a6f902230b7a1f0 (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
// $Id$

#include "Domain_Application_Impl.h"
#include "ace/Log_Msg.h"
#include "ace/streams.h"
#include "DAnCE/Logger/Log_Macros.h"

namespace DAnCE
{

  DomainApplication_Impl::DomainApplication_Impl (
    TNam2Nm & nams,
    const Deployment::Properties & configProperty,
    Deployment::Connections& conn)
      : nams_ (nams)
  {
    DANCE_TRACE("DomainApplication_Impl::DomainApplication_Impl");
    this->startLaunch (configProperty);
    conn = this->connections_;
  }

  DomainApplication_Impl::~DomainApplication_Impl()
  {
    DANCE_TRACE ("DomainApplication_Impl::~DomainApplication_Impl()");

    try
      {
        for (TApp2Mgr::iterator iter = this->node_applications_.begin();
             iter != this->node_applications_.end();
             ++iter)
          {
            (*iter).int_id_->destroyApplication ( (*iter).ext_id_.in());
          }
        this->node_applications_.unbind_all();
      }
    catch (CORBA::Exception &e)
      {
        DANCE_ERROR((LM_ERROR, DLINFO
                    ACE_TEXT("DomainApplication_Impl::~DomainApplication_Impl - ")
                    ACE_TEXT("caught a CORBA exception %C(%C) \"%C\"\n"),
                    e._name(), e._rep_id(), e._info().c_str()));
      }
    catch(...)
      {
        DANCE_ERROR((LM_ERROR, DLINFO ACE_TEXT("DomainApplication_Impl::~DomainApplication_Impl - ")
                     ACE_TEXT("caught an unknown exception.\n")));
      }
  }

  void
  DomainApplication_Impl::finishLaunch (const Deployment::Connections & connections,
                                        CORBA::Boolean start)
  {
    DANCE_TRACE ("DomainApplication_Impl::finishLaunch");
    DANCE_DEBUG ((LM_DEBUG, DLINFO ACE_TEXT("DomainApplication_impl::finishLaunch - ")
                  ACE_TEXT("connections length is %d\n"), connections.length()));
    for (TApp2Mgr::iterator iter = this->node_applications_.begin();
         iter != this->node_applications_.end();
         ++iter)
      {
        (*iter).ext_id_->finishLaunch (connections, start);
      }
  }

  void
  DomainApplication_Impl::start ()
  {
    DANCE_TRACE ("DomainApplication_Impl::start");
    for (TApp2Mgr::iterator iter = this->node_applications_.begin();
         iter != this->node_applications_.end();
         ++iter)
      {
        (*iter).ext_id_->start ();
      }
  }

  void
  DomainApplication_Impl::startLaunch (
    const Deployment::Properties & configProperty)
  {
    DANCE_TRACE ("DomainApplication_Impl::startLaunch");

    for (TNam2Nm::iterator iter = this->nams_.begin();
         iter != this->nams_.end();
         ++iter)
      {
        DANCE_DEBUG ((LM_TRACE, DLINFO ACE_TEXT("DomainApplication_Impl::startLaunch - ")
                      ACE_TEXT("Invoking startLaunch on an application\n")));
        ::Deployment::Connections_var conn;
        Deployment::Application_ptr na = (*iter).ext_id_->startLaunch (configProperty, conn.out());
        //Deployment::NodeApplication_ptr na = Deployment::NodeApplication::_narrow (a);
        if (CORBA::is_nil (na))
          {
            DANCE_ERROR ((LM_ERROR, DLINFO
                         ACE_TEXT("DomainApplication_Impl::startLaunch -")
                         ACE_TEXT("Received nil object reference from  startLaunch on node managers.\n")));
            throw Deployment::StartError();
          }
        DANCE_DEBUG ((LM_TRACE, DLINFO
                      ACE_TEXT("DomainApplication_Impl::startLaunch - ")
                      ACE_TEXT("Application startLaunch succeeded, received %u connections\n"),
                      conn->length ()));

        this->node_applications_.bind (na, (*iter).ext_id_);

        size_t before = this->connections_.length();
        this->connections_.length (before + conn->length());
        for (size_t i = 0; i < conn->length(); ++i)
          {
            this->connections_[before+i] = (*conn) [i];
          }
      }

    DANCE_DEBUG ((LM_DEBUG, DLINFO
                  ACE_TEXT("DomainApplication_Impl::startLaunch - ")
                  ACE_TEXT("Received %u connections from applications\n"),
                  this->connections_.length ()));
  }

} // DAnCE