summaryrefslogtreecommitdiff
path: root/libodb/odb/details/win32/once.ixx
diff options
context:
space:
mode:
authorKaren Arutyunov <karen@codesynthesis.com>2024-01-24 17:03:38 +0300
committerKaren Arutyunov <karen@codesynthesis.com>2024-01-24 17:03:38 +0300
commit0f1f6841ce5a50d5b315c24d796a2d8e2627d136 (patch)
treee16bbf9e23ca75a88b8af032c4e3ed299ca8db66 /libodb/odb/details/win32/once.ixx
parent823026b58211a4166de06ac243d978dcb9930271 (diff)
parent26e36b3a9d7b49d46ecfa69b447482251acba8ac (diff)
Merge branch 'libodb' into multi-package
Diffstat (limited to 'libodb/odb/details/win32/once.ixx')
-rw-r--r--libodb/odb/details/win32/once.ixx42
1 files changed, 42 insertions, 0 deletions
diff --git a/libodb/odb/details/win32/once.ixx b/libodb/odb/details/win32/once.ixx
new file mode 100644
index 0000000..1638706
--- /dev/null
+++ b/libodb/odb/details/win32/once.ixx
@@ -0,0 +1,42 @@
+// file : odb/details/win32/once.ixx
+// license : GNU GPL v2; see accompanying LICENSE file
+
+#include <odb/details/win32/lock.hxx>
+
+namespace odb
+{
+ namespace details
+ {
+ inline void
+ win32_once (win32_once_t& o, void (*func) ())
+ {
+ win32_lock l (win32_once_cs_);
+
+ if (o == 0)
+ {
+ o = 1;
+ l.unlock ();
+ func ();
+ }
+ }
+
+ inline once::
+ once ()
+ : called_ (false)
+ {
+ }
+
+ inline void once::
+ call (void (*func) ())
+ {
+ win32_lock l (win32_once_cs_);
+
+ if (!called_)
+ {
+ called_ = true;
+ l.unlock ();
+ func ();
+ }
+ }
+ }
+}