Chris@16
|
1 //////////////////////////////////////////////////////////////////////////////
|
Chris@16
|
2 //
|
Chris@16
|
3 // (C) Copyright Ion Gaztanaga 2005-2012. Distributed under the Boost
|
Chris@16
|
4 // Software License, Version 1.0. (See accompanying file
|
Chris@16
|
5 // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
Chris@16
|
6 //
|
Chris@16
|
7 // See http://www.boost.org/libs/interprocess for documentation.
|
Chris@16
|
8 //
|
Chris@16
|
9 //////////////////////////////////////////////////////////////////////////////
|
Chris@16
|
10
|
Chris@16
|
11 #ifndef BOOST_INTERPROCESS_NAMED_CONDITION_ANY_HPP
|
Chris@16
|
12 #define BOOST_INTERPROCESS_NAMED_CONDITION_ANY_HPP
|
Chris@16
|
13
|
Chris@101
|
14 #ifndef BOOST_CONFIG_HPP
|
Chris@101
|
15 # include <boost/config.hpp>
|
Chris@101
|
16 #endif
|
Chris@101
|
17 #
|
Chris@101
|
18 #if defined(BOOST_HAS_PRAGMA_ONCE)
|
Chris@16
|
19 # pragma once
|
Chris@16
|
20 #endif
|
Chris@16
|
21
|
Chris@16
|
22 #include <boost/interprocess/detail/config_begin.hpp>
|
Chris@16
|
23 #include <boost/interprocess/detail/workaround.hpp>
|
Chris@16
|
24 #include <boost/interprocess/creation_tags.hpp>
|
Chris@16
|
25 #include <boost/interprocess/exceptions.hpp>
|
Chris@16
|
26 #include <boost/interprocess/detail/interprocess_tester.hpp>
|
Chris@16
|
27 #include <boost/interprocess/permissions.hpp>
|
Chris@16
|
28 #include <boost/interprocess/detail/posix_time_types_wrk.hpp>
|
Chris@16
|
29 #include <boost/interprocess/sync/detail/locks.hpp>
|
Chris@16
|
30 #if !defined(BOOST_INTERPROCESS_FORCE_GENERIC_EMULATION) && defined (BOOST_INTERPROCESS_WINDOWS)
|
Chris@16
|
31 #include <boost/interprocess/sync/windows/named_condition_any.hpp>
|
Chris@16
|
32 #define BOOST_INTERPROCESS_USE_WINDOWS
|
Chris@16
|
33 #else
|
Chris@16
|
34 #include <boost/interprocess/sync/shm/named_condition_any.hpp>
|
Chris@16
|
35 #endif
|
Chris@16
|
36
|
Chris@16
|
37 //!\file
|
Chris@16
|
38 //!Describes a named condition class for inter-process synchronization
|
Chris@16
|
39
|
Chris@16
|
40 namespace boost {
|
Chris@16
|
41 namespace interprocess {
|
Chris@16
|
42
|
Chris@101
|
43 #if !defined(BOOST_INTERPROCESS_DOXYGEN_INVOKED)
|
Chris@16
|
44 namespace ipcdetail{ class interprocess_tester; }
|
Chris@101
|
45 #endif //#ifndef BOOST_INTERPROCESS_DOXYGEN_INVOKED
|
Chris@16
|
46
|
Chris@16
|
47 //! A global condition variable that can be created by name.
|
Chris@16
|
48 //! This condition variable is designed to work with named_mutex and
|
Chris@16
|
49 //! can't be placed in shared memory or memory mapped files.
|
Chris@16
|
50 class named_condition_any
|
Chris@16
|
51 {
|
Chris@101
|
52 #if !defined(BOOST_INTERPROCESS_DOXYGEN_INVOKED)
|
Chris@16
|
53 //Non-copyable
|
Chris@16
|
54 named_condition_any();
|
Chris@16
|
55 named_condition_any(const named_condition_any &);
|
Chris@16
|
56 named_condition_any &operator=(const named_condition_any &);
|
Chris@101
|
57 #endif //#ifndef BOOST_INTERPROCESS_DOXYGEN_INVOKED
|
Chris@16
|
58 public:
|
Chris@16
|
59 //!Creates a global condition with a name.
|
Chris@16
|
60 //!If the condition can't be created throws interprocess_exception
|
Chris@16
|
61 named_condition_any(create_only_t, const char *name, const permissions &perm = permissions())
|
Chris@16
|
62 : m_cond(create_only_t(), name, perm)
|
Chris@16
|
63 {}
|
Chris@16
|
64
|
Chris@16
|
65 //!Opens or creates a global condition with a name.
|
Chris@16
|
66 //!If the condition is created, this call is equivalent to
|
Chris@16
|
67 //!named_condition_any(create_only_t, ... )
|
Chris@16
|
68 //!If the condition is already created, this call is equivalent
|
Chris@16
|
69 //!named_condition_any(open_only_t, ... )
|
Chris@16
|
70 //!Does not throw
|
Chris@16
|
71 named_condition_any(open_or_create_t, const char *name, const permissions &perm = permissions())
|
Chris@16
|
72 : m_cond(open_or_create_t(), name, perm)
|
Chris@16
|
73 {}
|
Chris@16
|
74
|
Chris@16
|
75 //!Opens a global condition with a name if that condition is previously
|
Chris@16
|
76 //!created. If it is not previously created this function throws
|
Chris@16
|
77 //!interprocess_exception.
|
Chris@16
|
78 named_condition_any(open_only_t, const char *name)
|
Chris@16
|
79 : m_cond(open_only_t(), name)
|
Chris@16
|
80 {}
|
Chris@16
|
81
|
Chris@16
|
82 //!Destroys *this and indicates that the calling process is finished using
|
Chris@16
|
83 //!the resource. The destructor function will deallocate
|
Chris@16
|
84 //!any system resources allocated by the system for use by this process for
|
Chris@16
|
85 //!this resource. The resource can still be opened again calling
|
Chris@16
|
86 //!the open constructor overload. To erase the resource from the system
|
Chris@16
|
87 //!use remove().
|
Chris@16
|
88 ~named_condition_any()
|
Chris@16
|
89 {}
|
Chris@16
|
90
|
Chris@16
|
91 //!If there is a thread waiting on *this, change that
|
Chris@16
|
92 //!thread's state to ready. Otherwise there is no effect.*/
|
Chris@16
|
93 void notify_one()
|
Chris@16
|
94 { m_cond.notify_one(); }
|
Chris@16
|
95
|
Chris@16
|
96 //!Change the state of all threads waiting on *this to ready.
|
Chris@16
|
97 //!If there are no waiting threads, notify_all() has no effect.
|
Chris@16
|
98 void notify_all()
|
Chris@16
|
99 { m_cond.notify_all(); }
|
Chris@16
|
100
|
Chris@16
|
101 //!Releases the lock on the named_mutex object associated with lock, blocks
|
Chris@16
|
102 //!the current thread of execution until readied by a call to
|
Chris@16
|
103 //!this->notify_one() or this->notify_all(), and then reacquires the lock.
|
Chris@16
|
104 template <typename L>
|
Chris@16
|
105 void wait(L& lock)
|
Chris@16
|
106 { return m_cond.wait(lock); }
|
Chris@16
|
107
|
Chris@16
|
108 //!The same as:
|
Chris@16
|
109 //!while (!pred()) wait(lock)
|
Chris@16
|
110 template <typename L, typename Pr>
|
Chris@16
|
111 void wait(L& lock, Pr pred)
|
Chris@16
|
112 { return m_cond.wait(lock, pred); }
|
Chris@16
|
113
|
Chris@16
|
114 //!Releases the lock on the named_mutex object associated with lock, blocks
|
Chris@16
|
115 //!the current thread of execution until readied by a call to
|
Chris@16
|
116 //!this->notify_one() or this->notify_all(), or until time abs_time is reached,
|
Chris@16
|
117 //!and then reacquires the lock.
|
Chris@16
|
118 //!Returns: false if time abs_time is reached, otherwise true.
|
Chris@16
|
119 template <typename L>
|
Chris@16
|
120 bool timed_wait(L& lock, const boost::posix_time::ptime &abs_time)
|
Chris@16
|
121 { return m_cond.timed_wait(lock, abs_time); }
|
Chris@16
|
122
|
Chris@16
|
123 //!The same as: while (!pred()) {
|
Chris@16
|
124 //! if (!timed_wait(lock, abs_time)) return pred();
|
Chris@16
|
125 //! } return true;
|
Chris@16
|
126 template <typename L, typename Pr>
|
Chris@16
|
127 bool timed_wait(L& lock, const boost::posix_time::ptime &abs_time, Pr pred)
|
Chris@16
|
128 { return m_cond.timed_wait(lock, abs_time, pred); }
|
Chris@16
|
129
|
Chris@16
|
130 //!Erases a named condition from the system.
|
Chris@16
|
131 //!Returns false on error. Never throws.
|
Chris@16
|
132 static bool remove(const char *name)
|
Chris@16
|
133 { return condition_any_type::remove(name); }
|
Chris@16
|
134
|
Chris@101
|
135 #if !defined(BOOST_INTERPROCESS_DOXYGEN_INVOKED)
|
Chris@16
|
136 private:
|
Chris@16
|
137 #if defined(BOOST_INTERPROCESS_USE_WINDOWS)
|
Chris@16
|
138 typedef ipcdetail::windows_named_condition_any condition_any_type;
|
Chris@16
|
139 #else
|
Chris@16
|
140 typedef ipcdetail::shm_named_condition_any condition_any_type;
|
Chris@16
|
141 #endif
|
Chris@16
|
142 condition_any_type m_cond;
|
Chris@16
|
143
|
Chris@16
|
144 friend class ipcdetail::interprocess_tester;
|
Chris@16
|
145 void dont_close_on_destruction()
|
Chris@16
|
146 { ipcdetail::interprocess_tester::dont_close_on_destruction(m_cond); }
|
Chris@101
|
147 #endif //#ifndef BOOST_INTERPROCESS_DOXYGEN_INVOKED
|
Chris@16
|
148 };
|
Chris@16
|
149
|
Chris@16
|
150 } //namespace interprocess
|
Chris@16
|
151 } //namespace boost
|
Chris@16
|
152
|
Chris@16
|
153 #include <boost/interprocess/detail/config_end.hpp>
|
Chris@16
|
154
|
Chris@16
|
155 #endif // BOOST_INTERPROCESS_NAMED_CONDITION_ANY_HPP
|