From 698f8c2f01ea549d77d7dc3338a12e04c11057b9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Wed, 17 Apr 2024 14:02:58 +0200 Subject: Adding upstream version 1.64.0+dfsg1. Signed-off-by: Daniel Baumann --- library/std/src/sys_common/condvar.rs | 56 +++++++++++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 library/std/src/sys_common/condvar.rs (limited to 'library/std/src/sys_common/condvar.rs') diff --git a/library/std/src/sys_common/condvar.rs b/library/std/src/sys_common/condvar.rs new file mode 100644 index 000000000..f3ac1061b --- /dev/null +++ b/library/std/src/sys_common/condvar.rs @@ -0,0 +1,56 @@ +use crate::sys::locks as imp; +use crate::sys_common::mutex::MovableMutex; +use crate::time::Duration; + +mod check; + +type CondvarCheck = ::Check; + +/// An OS-based condition variable. +pub struct Condvar { + inner: imp::MovableCondvar, + check: CondvarCheck, +} + +impl Condvar { + /// Creates a new condition variable for use. + #[inline] + pub const fn new() -> Self { + Self { inner: imp::MovableCondvar::new(), check: CondvarCheck::new() } + } + + /// Signals one waiter on this condition variable to wake up. + #[inline] + pub fn notify_one(&self) { + unsafe { self.inner.notify_one() }; + } + + /// Awakens all current waiters on this condition variable. + #[inline] + pub fn notify_all(&self) { + unsafe { self.inner.notify_all() }; + } + + /// Waits for a signal on the specified mutex. + /// + /// Behavior is undefined if the mutex is not locked by the current thread. + /// + /// May panic if used with more than one mutex. + #[inline] + pub unsafe fn wait(&self, mutex: &MovableMutex) { + self.check.verify(mutex); + self.inner.wait(mutex.raw()) + } + + /// Waits for a signal on the specified mutex with a timeout duration + /// specified by `dur` (a relative time into the future). + /// + /// Behavior is undefined if the mutex is not locked by the current thread. + /// + /// May panic if used with more than one mutex. + #[inline] + pub unsafe fn wait_timeout(&self, mutex: &MovableMutex, dur: Duration) -> bool { + self.check.verify(mutex); + self.inner.wait_timeout(mutex.raw(), dur) + } +} -- cgit v1.2.3