blob: daefddca2c0e7446f38667ca8c37c219a8cc62a7 (
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
|
/* -*- C++ -*- */
// ============================================================================
/**
* @file RTEvent_Logging_Service.h
*
* Front End of the Telecom Log Service
* RTEvent_Logging_Service
*
* @author D A Hanvey (d.hanvey@qub.ac.uk)
*/
// ============================================================================
#ifndef RTEVENT_LOGGING_SERVICE_H
#define RTEVENT_LOGGING_SERVICE_H
#include "ace/Task.h"
#include "orbsvcs/CosNamingC.h"
#include "orbsvcs/Log/RTEventLogFactory_i.h"
class RTEvent_Logging_Service
: public ACE_Task_Base
{
// = TITLE
// RTEvent_Logging_Service
//
// = DESCRIPTION
// Implementation of the Telecom Log Service
public:
RTEvent_Logging_Service (void);
// Constructor.
virtual ~RTEvent_Logging_Service (void);
// Destructor.
int init (int argc, ACE_TCHAR* argv[]);
// Initializes the Telecom Log Service.
int run (void);
// Run the Telecom Log Service.
// Returns 0 on success, -1 on error.
void shutdown (void);
// Shutdown the Telecom Log Service.
// Returns 0 on success, -1 on error.
protected:
void init_ORB (int& argc, ACE_TCHAR *argv []);
// initializes the ORB.
int parse_args (int argc, ACE_TCHAR* argv[]);
// parse the command line args
void resolve_naming_service (void);
// Resolve the naming service.
int svc ();
// Run worker threads.
private:
// = Data members
TAO_RTEventLogFactory_i *rtevent_log_factory_;
// The RTEvent Log Factory.
CORBA::ORB_var orb_;
// The ORB that we use.
PortableServer::POA_var poa_;
// Reference to the root poa.
CosNaming::NamingContext_var naming_;
// A naming context.
ACE_CString service_name_;
// The name we use to bind with the NameService
const ACE_TCHAR* ior_file_name_;
// The name of the file were we output the factory IOR.
const ACE_TCHAR* pid_file_name_;
// The name of a file where the process stores its pid
bool bind_to_naming_service_;
// If true, bind to naming service
int nthreads_;
// Number of worker threads.
};
#endif /* RTEVENT_LOGGING_SERVICE_H */
|