blob: faff12d404c8a1201b9816376aa77773078a6f35 (
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
|
// -*- C++ -*-
//=============================================================================
/**
* @file Node_Manager_Module.h
*
* @brief To start NodeManager by starter
*
* @author Vinzenz Tornow <vt@prismtech.com>
* @author William R. Otte <wotte@dre.vanderbilt.edu>
*/
//=============================================================================
#ifndef NODE_MANAGER_MODULE_H
#define NODE_MANAGER_MODULE_H
#include /**/ "ace/pre.h"
#include "ace/Service_Config.h"
#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */
#include "ace/Vector_T.h"
#include "ace/Map_Manager.h"
#include "ace/Null_Mutex.h"
#include "tao/ORB.h"
#include "tao/PortableServer/PortableServer.h"
#include "orbsvcs/CosNamingC.h"
#include "dance/DAnCE_Utility.h"
#include "dance/DAnCE_ArtifactInstallationC.h"
#include <string>
namespace DAnCE
{
class NodeManager_Impl;
}
/**
* @class Node_Manager_Module
*
* @brief The shared object that is instantiated when the node manager
* module/library is dynamically loaded.
*
* This class runs the node manager instance
*/
class DAnCE_NodeManager_Module
{
public:
/// Constructor.
DAnCE_NodeManager_Module (void);
/// Destructor.
~DAnCE_NodeManager_Module (void);
/// Overload the base class method to create a new instance
/// of a DAnCE_NodeManager_Module object.
CORBA::Object_ptr init (CORBA::ORB_ptr orb,
int argc,
ACE_TCHAR *argv []);
private:
const char * usage (void);
bool parse_args (int argc, ACE_TCHAR *argv []);
struct SOptions
{
bool process_ns_;
const ACE_TCHAR* process_ns_file_;
bool create_plan_ns_;
const ACE_TCHAR* create_plan_ns_ior_;
bool rebind_plan_ns_;
const ACE_TCHAR* rebind_plan_ns_ior_;
bool port_indirection_;
ACE_Vector<ACE_TString> node_managers_;
const ACE_TCHAR * cs_path_;
unsigned int timeout_;
const ACE_TCHAR * server_args_;
const ACE_TCHAR * domain_nc_;
const ACE_TCHAR * instance_nc_;
unsigned int threads_;
std::string locality_config_;
std::string node_config_;
SOptions();
};
void register_value_factories (void);
void create_poas (void);
void create_nm_properties (DAnCE::Utility::PROPERTY_MAP &props);
void load_artifact_installation_modules (int argc, ACE_TCHAR *argv []);
/// Here we store the servants.
typedef ACE_Map_Manager < ACE_TString,
DAnCE::NodeManager_Impl *,
ACE_Null_Mutex > Servant_Map;
Servant_Map nm_map_;
CORBA::ORB_var orb_;
CosNaming::NamingContext_var domain_nc_;
SOptions options_;
PortableServer::POA_var root_poa_;
PortableServer::POA_var nm_poa_;
DAnCE::ArtifactInstallation_var installer_;
};
#include /**/ "ace/post.h"
#endif /* NODE_MANAGER_MODULE_H */
|