summaryrefslogtreecommitdiff
path: root/ACE/examples/Logger/simple-server/Logging_Handler.h
diff options
context:
space:
mode:
Diffstat (limited to 'ACE/examples/Logger/simple-server/Logging_Handler.h')
-rw-r--r--ACE/examples/Logger/simple-server/Logging_Handler.h70
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 */