diff options
author | Karen Arutyunov <karen@codesynthesis.com> | 2024-01-24 17:03:38 +0300 |
---|---|---|
committer | Karen Arutyunov <karen@codesynthesis.com> | 2024-01-24 17:03:38 +0300 |
commit | 0f1f6841ce5a50d5b315c24d796a2d8e2627d136 (patch) | |
tree | e16bbf9e23ca75a88b8af032c4e3ed299ca8db66 /libodb/odb/details/win32/condition.ixx | |
parent | 823026b58211a4166de06ac243d978dcb9930271 (diff) | |
parent | 26e36b3a9d7b49d46ecfa69b447482251acba8ac (diff) |
Merge branch 'libodb' into multi-package
Diffstat (limited to 'libodb/odb/details/win32/condition.ixx')
-rw-r--r-- | libodb/odb/details/win32/condition.ixx | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/libodb/odb/details/win32/condition.ixx b/libodb/odb/details/win32/condition.ixx new file mode 100644 index 0000000..37a2bac --- /dev/null +++ b/libodb/odb/details/win32/condition.ixx @@ -0,0 +1,30 @@ +// file : odb/details/win32/condition.ixx +// license : GNU GPL v2; see accompanying LICENSE file + +#include <odb/details/win32/exceptions.hxx> + +namespace odb +{ + namespace details + { + inline condition:: + ~condition () + { + CloseHandle (event_); + } + + inline condition:: + condition (mutex& mutex) + : mutex_ (mutex), waiters_ (0), signals_ (0) + { + // Auto-reset event. Releases one waiting thread and automatically + // resets the event state. If no threads are waiting the event + // remains signalled. + // + event_ = CreateEvent (0, false, false, 0); + + if (event_ == 0) + throw win32_exception (); + } + } +} |