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
|
// This server daemon collects, formats, and displays logging
// @(#)server_loggerd.cpp 1.1 10/18/96
// information forwarded from client daemons running on other hosts in
// the network.
// In addition, it also illustrates how the ACE_Reactor framework is
// used.
#include "ace/Get_Opt.h"
#include "ace/Log_Msg.h"
#include "Logging_Acceptor.h"
#include "Reactor_Singleton.h"
static sig_atomic_t finished = 0;
static void
handler (int)
{
finished = 1;
}
// It doesn't get anymore const than this....
static const u_short PORT = ACE_DEFAULT_SERVER_PORT;
int
main (int argc, char *argv[])
{
Logging_Acceptor peer_acceptor;
ACE_INET_Addr addr (PORT);
ACE_Get_Opt get_opt (argc, argv, "p:");
ACE_Sig_Action sig ((ACE_SignalHandler) handler, SIGINT);
for (int c; (c = get_opt ()) != -1; )
switch (c)
{
case 'p':
addr.set (ACE_OS::atoi (get_opt.optarg));
break;
default:
break;
}
if (peer_acceptor.open (addr) == -1)
ACE_ERROR_RETURN ((LM_ERROR, "%p\n", "open"), -1);
else if (REACTOR::instance ()->register_handler
(&peer_acceptor, ACE_Event_Handler::READ_MASK) == -1)
ACE_ERROR_RETURN ((LM_ERROR, "registering service with ACE_Reactor\n"), -1);
// Run forever, performing logging service.
ACE_DEBUG ((LM_DEBUG, "(%P|%t) starting up server logging daemon\n"));
while (!finished)
REACTOR::instance ()->handle_events ();
ACE_DEBUG ((LM_DEBUG, "(%P|%t) shutting down server logging daemon\n"));
return 0;
}
|