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
|
// $Id$
#ifndef STARTER_H_
#define STARTER_H_
#include "ace/String_Base.h"
#include "tao/ORB.h"
#include "tao/Object.h"
#include "ace/Map_Manager.h"
#include "ace/Null_Mutex.h"
#include "DAnCE/Logger/Logger_Service.h"
namespace DAnCE
{
class Starter
{
public:
Starter (int argc, ACE_TCHAR* argv[]);
~Starter();
void execute();
private:
struct Node
{
ACE_CString iorfile_;
ACE_CString ior_;
CORBA::Object_var obj;
Node() : obj (CORBA::Object::_nil()) {};
};
auto_ptr<DAnCE::Logger_Service> logger_;
CORBA::ORB_var orb_;
int optLogLevel_;
int argc_;
ACE_TCHAR** argv_;
bool optNS_;
ACE_TString optNSFile_;
ACE_CString optNSOptions_;
ACE_Map_Manager<ACE_CString, Node, ACE_Null_Mutex> nodes_;
bool optEM_;
ACE_CString optEMFile_;
ACE_CString optGenObjKey_;
bool optPLB_;
bool optPL_;
void parseArgs (int argc, ACE_TCHAR* argv[]);
void usage ();
void generateObjectKey (const char * keyargs);
void generateObjectKey (const char * node
, const char * plan
, const char * component
, const char * port);
void write_IOR (const ACE_TCHAR * ior_file_name, const char* ior);
void initNaming();
CORBA::Object_ptr initNodeManager (const char * node);
CORBA::Object_ptr initExecutionManager();
void runPlanLauncher();
void argCopyForNaming (int & c, char **& v);
void argCopyForNode (const char * node, int & c, char **& v);
void argCopyForEM (int & c, char **& v);
void argCopyForPL (int & c, char **& v);
void releaseArgs (int c, char ** v);
static bool isPossibleOption(const char* opt);
void configure_logging_backend (void);
};
} // DAnCE
#endif /*STARTER_H_*/
|