summaryrefslogtreecommitdiff
path: root/ACE/examples/Service_Configurator/IPC-tests/server/Handle_Timeout.inl
diff options
context:
space:
mode:
Diffstat (limited to 'ACE/examples/Service_Configurator/IPC-tests/server/Handle_Timeout.inl')
-rw-r--r--ACE/examples/Service_Configurator/IPC-tests/server/Handle_Timeout.inl95
1 files changed, 95 insertions, 0 deletions
diff --git a/ACE/examples/Service_Configurator/IPC-tests/server/Handle_Timeout.inl b/ACE/examples/Service_Configurator/IPC-tests/server/Handle_Timeout.inl
new file mode 100644
index 00000000000..5a9bed73c07
--- /dev/null
+++ b/ACE/examples/Service_Configurator/IPC-tests/server/Handle_Timeout.inl
@@ -0,0 +1,95 @@
+/* -*- C++ -*- */
+// $Id$
+
+#include "ace/Service_Config.h"
+#include "ace/Get_Opt.h"
+#include "ace/OS_NS_stdio.h"
+#include "ace/OS_NS_string.h"
+#include "ace/Truncate.h"
+
+ACE_INLINE
+Handle_Timeout::Handle_Timeout (void): count (0)
+{
+}
+
+ACE_INLINE int
+Handle_Timeout::info (ACE_TCHAR **strp, size_t length) const
+{
+ ACE_TCHAR buf[BUFSIZ];
+
+ ACE_OS::strcpy (buf, ACE_TEXT("# tests timeout facility\n"));
+
+ if (*strp == 0 && (*strp = ACE_OS::strdup (buf)) == 0)
+ {
+ return -1;
+ }
+ else
+ {
+ ACE_OS::strncpy (*strp, buf, length);
+ }
+
+ return ACE_Utils::truncate_cast<int> (ACE_OS::strlen (buf));
+}
+
+ACE_INLINE int
+Handle_Timeout::init (int argc, ACE_TCHAR *argv[])
+{
+ ACE_Time_Value delta (10);
+ ACE_Time_Value interval (1);
+ ACE_Get_Opt get_opt (argc, argv, ACE_TEXT("a:d:i:"), 0);
+ intptr_t arg = 0;
+
+ for (int c; (c = get_opt ()) != -1; )
+ switch (c)
+ {
+ case 'd':
+ delta.sec (ACE_OS::atoi (get_opt.opt_arg ()));
+ break;
+ case 'i':
+ interval.sec (ACE_OS::atoi (get_opt.opt_arg ()));
+ break;
+ case 'a':
+ arg = ACE_OS::atoi (get_opt.opt_arg ());
+ break;
+ default:
+ break;
+ }
+
+ if (ACE_Reactor::instance ()->schedule_timer (this,
+ reinterpret_cast<void *> (arg),
+ delta,
+ interval) == -1)
+ return -1;
+ else
+ return 0;
+}
+
+ACE_INLINE int
+Handle_Timeout::fini (void)
+{
+ return 0;
+}
+
+ACE_INLINE ACE_HANDLE
+Handle_Timeout::get_handle (void) const
+{
+ return ACE_INVALID_HANDLE;
+}
+
+ACE_INLINE int
+Handle_Timeout::handle_timeout (const ACE_Time_Value &tv,
+ const void *arg)
+{
+ if (this->count++ >= 10)
+ return -1; // Automatically cancel periodic timer...
+
+ // Cast arg to a long, first, because a pointer is the same
+ // size as a long on all current ACE platforms.
+ ACE_DEBUG ((LM_INFO,
+ ACE_TEXT ("time for this(%u) expired at (%d, %d) with arg = %d\n"),
+ this,
+ tv.sec (),
+ tv.usec (),
+ (int) (ptrdiff_t) arg));
+ return 0;
+}