blob: 89395a38fa3bcd7ced271c09926e0661290f3641 (
plain) (
blame)
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
|
use std::{thread::{self, Thread}, time::Duration, any::Any};
pub trait Signal: Send + Sync + 'static {
/// Fire the signal, returning whether it is a stream signal. This is because streams do not
/// acquire a message when woken, so signals must be fired until one that does acquire a message
/// is fired, otherwise a wakeup could be missed, leading to a lost message until one is eagerly
/// grabbed by a receiver.
fn fire(&self) -> bool;
fn as_any(&self) -> &(dyn Any + 'static);
fn as_ptr(&self) -> *const ();
}
pub struct SyncSignal(Thread);
impl Default for SyncSignal {
fn default() -> Self {
Self(thread::current())
}
}
impl Signal for SyncSignal {
fn fire(&self) -> bool {
self.0.unpark();
false
}
fn as_any(&self) -> &(dyn Any + 'static) { self }
fn as_ptr(&self) -> *const () { self as *const _ as *const () }
}
impl SyncSignal {
pub fn wait(&self) { thread::park(); }
pub fn wait_timeout(&self, dur: Duration) { thread::park_timeout(dur); }
}
|