diff options
Diffstat (limited to 'ACE/examples/Logger/simple-server/Logging_Handler.h')
-rw-r--r-- | ACE/examples/Logger/simple-server/Logging_Handler.h | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/ACE/examples/Logger/simple-server/Logging_Handler.h b/ACE/examples/Logger/simple-server/Logging_Handler.h new file mode 100644 index 00000000000..4c211a3a04b --- /dev/null +++ b/ACE/examples/Logger/simple-server/Logging_Handler.h @@ -0,0 +1,70 @@ +/* -*- C++ -*- */ + + +//============================================================================= +/** + * @file Logging_Handler.h + * + * $Id$ + * + * @author Doug Schmidt + */ +//============================================================================= + + +#ifndef _CLIENT_HANDLER_H +#define _CLIENT_HANDLER_H + +#include "ace/Event_Handler.h" + +#if !defined (ACE_LACKS_PRAGMA_ONCE) +# pragma once +#endif /* ACE_LACKS_PRAGMA_ONCE */ + +#include "ace/INET_Addr.h" +#include "ace/SOCK_Stream.h" +#include "ace/os_include/os_netdb.h" + +/** + * @class Logging_Handler + * + * @brief Receive client message from the remote clients. + * + * This class demonstrates how to receive messages from remote + * clients using the notification mechanisms in the + * <ACE_Reactor>. In addition, it also illustrates how to + * utilize the <ACE_Reactor> timer mechanisms, as well. + */ +class Logging_Handler : public ACE_Event_Handler +{ +public: + Logging_Handler (void); + + // = Hooks for opening and closing handlers. + virtual int open (void); + virtual int close (void); + + /// Conversion operators. + ACE_SOCK_Stream &peer (void); + +protected: + // = Demultiplexing hooks. + virtual ACE_HANDLE get_handle (void) const; + virtual int handle_input (ACE_HANDLE); + virtual int handle_close (ACE_HANDLE = ACE_INVALID_HANDLE, + ACE_Reactor_Mask = ACE_Event_Handler::ALL_EVENTS_MASK); + virtual int handle_timeout (const ACE_Time_Value &tv, const void *arg); + + // = Really should be private... + /// Ensure dynamic allocation. + virtual ~Logging_Handler (void); + +private: + /// Host we are connected to. + char host_name_[MAXHOSTNAMELEN + 1]; + + /// Connection with client + ACE_SOCK_Stream cli_stream_; +}; + +#endif /* _CLIENT_HANDLER_H */ |