summaryrefslogtreecommitdiff
path: root/deps/acelite/ace/Manual_Event.h
diff options
context:
space:
mode:
Diffstat (limited to 'deps/acelite/ace/Manual_Event.h')
-rw-r--r--deps/acelite/ace/Manual_Event.h125
1 files changed, 125 insertions, 0 deletions
diff --git a/deps/acelite/ace/Manual_Event.h b/deps/acelite/ace/Manual_Event.h
new file mode 100644
index 0000000000..40b4da5add
--- /dev/null
+++ b/deps/acelite/ace/Manual_Event.h
@@ -0,0 +1,125 @@
+// -*- C++ -*-
+
+//==========================================================================
+/**
+ * @file Manual_Event.h
+ *
+ * Moved from Synch.h.
+ *
+ * @author Douglas C. Schmidt <schmidt@cs.wustl.edu>
+ */
+//==========================================================================
+
+#ifndef ACE_MANUAL_EVENT_H
+#define ACE_MANUAL_EVENT_H
+#include /**/ "ace/pre.h"
+
+#include /**/ "ace/ACE_export.h"
+
+#if !defined (ACE_LACKS_PRAGMA_ONCE)
+# pragma once
+#endif /* ACE_LACKS_PRAGMA_ONCE */
+
+#include "ace/Event.h"
+
+ACE_BEGIN_VERSIONED_NAMESPACE_DECL
+
+/**
+ * @class ACE_Manual_Event
+ *
+ * @brief Manual Events.
+ *
+ * Specialization of Event mechanism which wakes up all waiting
+ * thread on <signal>. All platforms support process-scope locking
+ * support. However, only Win32 platforms support global naming and
+ * system-scope locking support.
+ */
+template <class TIME_POLICY = ACE_System_Time_Policy>
+class ACE_Manual_Event_T : public ACE_Event_T<TIME_POLICY>
+{
+public:
+ /// Constructor which will create manual event
+ ACE_Manual_Event_T (int initial_state = 0,
+ int type = USYNC_THREAD,
+ const char *name = 0,
+ void *arg = 0) : ACE_Event_T<TIME_POLICY> (1,
+ initial_state,
+ type,
+ ACE_TEXT_CHAR_TO_TCHAR (name),
+ arg)
+ {
+ }
+
+#if defined (ACE_HAS_WCHAR)
+ /// Constructor which will create manual event (wchar_t version)
+ ACE_Manual_Event_T (int initial_state,
+ int type,
+ const wchar_t *name,
+ void *arg = 0) : ACE_Event_T<TIME_POLICY> (1,
+ initial_state,
+ type,
+ ACE_TEXT_WCHAR_TO_TCHAR (name),
+ arg)
+ {
+ }
+#endif /* ACE_HAS_WCHAR */
+
+ /// Default dtor.
+ ~ACE_Manual_Event_T (void)
+ {
+ }
+
+ /// Dump the state of an object.
+ void dump (void) const
+ {
+#if defined (ACE_HAS_DUMP)
+ ACE_Event_T<TIME_POLICY>::dump ();
+#endif /* ACE_HAS_DUMP */
+ }
+
+ /// Declare the dynamic allocation hooks
+ ACE_ALLOC_HOOK_DECLARE;
+};
+
+class ACE_Manual_Event :
+ public ACE_Manual_Event_T<ACE_System_Time_Policy>
+{
+public:
+ /// Constructor which will create auto event
+ ACE_Manual_Event (int initial_state = 0,
+ int type = USYNC_THREAD,
+ const char *name = 0,
+ void *arg = 0)
+ : ACE_Manual_Event_T<ACE_System_Time_Policy> (initial_state, type, name, arg)
+ {}
+
+#if defined (ACE_HAS_WCHAR)
+ /// Constructor which will create auto event (wchar_t version)
+ ACE_Manual_Event (int initial_state,
+ int type,
+ const wchar_t *name,
+ void *arg = 0)
+ : ACE_Manual_Event_T<ACE_System_Time_Policy> (initial_state, type, name, arg)
+ {}
+#endif /* ACE_HAS_WCHAR */
+
+ /// Default dtor.
+ virtual ~ACE_Manual_Event (void) {}
+};
+
+ACE_END_VERSIONED_NAMESPACE_DECL
+
+#if defined (__ACE_INLINE__)
+#include "ace/Manual_Event.inl"
+#endif /* __ACE_INLINE__ */
+
+#if defined (ACE_TEMPLATES_REQUIRE_SOURCE)
+#include "ace/Manual_Event.cpp"
+#endif /* ACE_TEMPLATES_REQUIRE_SOURCE */
+
+#if defined (ACE_TEMPLATES_REQUIRE_PRAGMA)
+#pragma implementation ("Manual_Event.cpp")
+#endif /* ACE_TEMPLATES_REQUIRE_PRAGMA */
+
+#include /**/ "ace/post.h"
+#endif /* ACE_MANUAL_EVENT_H */