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
|
#include "ace/Service_Config.h"
// @(#)main.cpp 1.1 10/18/96
#include "TS_Clerk_Handler.h"
#include "TS_Server_Handler.h"
#include "Client_Logging_Handler.h"
#include "Name_Handler.h"
#include "Token_Handler.h"
#include "Server_Logging_Handler.h"
#include "Logging_Strategy.h"
int
main (int argc, char *argv[])
{
ACE_Service_Config daemon;
// Try to link in the svc.conf entries dynamically.
if (daemon.open (argc, argv) == -1)
{
if (errno != ENOENT)
ACE_ERROR ((LM_ERROR, "%p\n%a", "open", 1));
else // Use static binding.
{
char *l_argv[3];
ACE_Service_Object *so;
l_argv[0] = "-p " ACE_DEFAULT_NAME_SERVER_PORT_STR;
l_argv[1] = 0;
so = ACE_SVC_INVOKE (ACE_Name_Acceptor);
if (so->init (1, l_argv) == -1)
ACE_ERROR ((LM_ERROR, "%p\n%a", "Name_Service", 1));
l_argv[0] = "-p " ACE_DEFAULT_TIME_SERVER_PORT_STR;
l_argv[1] = 0;
so = ACE_SVC_INVOKE (ACE_TS_Server_Acceptor);
if (so->init (2, l_argv) == -1)
ACE_ERROR ((LM_ERROR, "%p\n%a", "ACE_TS_Server_Acceptor", 1));
l_argv[0] = argv[0];
l_argv[1] = "-p 10011";
so = ACE_SVC_INVOKE (ACE_TS_Clerk_Processor);
if (so->init (2, l_argv) == -1)
ACE_ERROR ((LM_ERROR, "%p\n%a", "ACE_TS_Clerk_Processor", 1));
l_argv[0] = "-p " ACE_DEFAULT_TOKEN_SERVER_PORT_STR;
l_argv[1] = 0;
so = ACE_SVC_INVOKE (ACE_Token_Acceptor);
if (so->init (1, l_argv) == -1)
ACE_ERROR ((LM_ERROR, "%p\n%a", "Token_Service", 1));
l_argv[0] = "-p " ACE_DEFAULT_LOGGING_SERVER_PORT_STR;
l_argv[1] = 0;
so = ACE_SVC_INVOKE (ACE_Server_Logging_Acceptor);
if (so->init (1, l_argv) == -1)
ACE_ERROR ((LM_ERROR, "%p\n%a", "Logging_Service", 1));
l_argv[0] = "-p " ACE_DEFAULT_THR_LOGGING_SERVER_PORT_STR;
l_argv[1] = 0;
so = ACE_SVC_INVOKE (ACE_Thr_Server_Logging_Acceptor);
if (so->init (1, l_argv) == -1)
ACE_ERROR ((LM_ERROR, "%p\n%a", "Thr_Logging_Service", 1));
}
}
// Run forever, performing the configured services until we are shut
// down by a SIGINT/SIGQUIT signal.
daemon.run_reactor_event_loop ();
return 0;
}
|