1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#![forbid(unsafe_code)]
use crate::{schedule_wake, TimerThreadNotStarted};
use core::future::Future;
use core::pin::Pin;
use core::task::{Context, Poll, Waker};
use std::sync::{Arc, Mutex};
use std::time::Instant;
#[must_use = "futures stay idle unless you await them"]
pub struct SleepFuture {
deadline: std::time::Instant,
waker: Arc<Mutex<Option<Waker>>>,
}
impl SleepFuture {
pub fn new(deadline: Instant) -> Self {
Self {
deadline,
waker: Arc::new(Mutex::new(None)),
}
}
}
impl Future for SleepFuture {
type Output = Result<(), TimerThreadNotStarted>;
fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> {
if self.deadline < std::time::Instant::now() {
return Poll::Ready(Ok(()));
}
let old_waker = self.waker.lock().unwrap().replace(cx.waker().clone());
if old_waker.is_none() {
schedule_wake(self.deadline, self.waker.clone())?;
}
Poll::Pending
}
}
pub async fn sleep_until(deadline: std::time::Instant) {
SleepFuture::new(deadline).await.unwrap();
}
pub async fn sleep_for(duration: core::time::Duration) {
SleepFuture::new(Instant::now() + duration).await.unwrap();
}