3 //=============================================================================
5 * @file TS_Server_Handler.h
7 * @author Prashant Jain
9 //=============================================================================
12 #ifndef ACE_TS_SERVER_HANDLER_H
13 #define ACE_TS_SERVER_HANDLER_H
15 #include "ace/Acceptor.h"
17 #if !defined (ACE_LACKS_PRAGMA_ONCE)
19 #endif /* ACE_LACKS_PRAGMA_ONCE */
21 #include "ace/SOCK_Acceptor.h"
22 #include "ace/Svc_Handler.h"
23 #include "ace/svc_export.h"
25 #include "Time_Request_Reply.h"
27 #if defined ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION_EXPORT
28 template class ACE_Svc_Export ACE_Svc_Handler
<ACE_SOCK_STREAM
, ACE_NULL_SYNCH
>;
29 #endif /* ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION_EXPORT */
32 * @class ACE_TS_Server_Handler
34 * @brief Product object created by <ACE_TS_Server_Acceptor>.
36 class ACE_Svc_Export ACE_TS_Server_Handler
: public ACE_Svc_Handler
<ACE_SOCK_STREAM
, ACE_NULL_SYNCH
>
39 /// Default constructor.
40 ACE_TS_Server_Handler (ACE_Thread_Manager
* = 0);
42 /// Activate this instance of the <ACE_TS_Server_Handler> (called by the
43 /// <ACE_Strategy_Acceptor>).
44 virtual int open (void * = 0);
47 /// Must be allocated dynamically.
48 ~ACE_TS_Server_Handler ();
50 // = Helper routines for the operations exported to clients.
52 /// Give up waiting (e.g., when a timeout occurs or a client shuts
53 /// down unexpectedly).
54 virtual int abandon ();
56 // = Low level routines for framing requests, dispatching
57 // operations, and returning replies.
59 /// Receive, frame, and decode the client's request.
60 virtual int recv_request ();
62 /// Dispatch the appropriate operation to handle the client's
64 virtual int dispatch ();
66 /// Special kind of reply
67 virtual int send_request (ACE_Time_Request
&);
69 // = Demultiplexing hooks.
70 /// Return the underlying <ACE_HANDLE>.
71 virtual ACE_HANDLE
get_handle () const;
73 /// Callback method invoked by the <ACE_Reactor> when client events
75 virtual int handle_input (ACE_HANDLE
);
78 /// Enable clients to limit the amount of time they wait.
79 virtual int handle_timeout (const ACE_Time_Value
&tv
, const void *arg
);
82 /// Cache request from the client.
83 ACE_Time_Request time_request_
;
85 /// Address of client we are connected with.
90 * @class ACE_TS_Server_Acceptor
92 * @brief This class contains the service-specific methods that can't
93 * easily be factored into the <ACE_Strategy_Acceptor>.
95 class ACE_TS_Server_Acceptor
: public ACE_Strategy_Acceptor
<ACE_TS_Server_Handler
, ACE_SOCK_ACCEPTOR
>
98 /// Dynamic linking hook.
99 virtual int init (int argc
, ACE_TCHAR
*argv
[]);
101 /// Parse svc.conf arguments.
102 int parse_args (int argc
, ACE_TCHAR
*argv
[]);
105 /// The scheduling strategy is designed for Reactive services.
106 ACE_Schedule_All_Reactive_Strategy
<ACE_TS_Server_Handler
> scheduling_strategy_
;
109 ACE_SVC_FACTORY_DECLARE (ACE_TS_Server_Acceptor
)
111 #endif /* ACE_TS_SERVER_HANDLER_H */