#waker #async #thread #run-time #future #token #task

thread-waker

Waker implementation using current thread token

2 stable releases

1.1.0 Aug 24, 2024
1.0.0 Jul 27, 2024

#483 in Asynchronous

Download history 90/week @ 2024-07-22 53/week @ 2024-07-29 166/week @ 2024-08-19 10/week @ 2024-08-26 19/week @ 2024-09-16 13/week @ 2024-09-23 31/week @ 2024-09-30

82 downloads per month

BSL-1.0 license

5KB

thread-waker

Rust Crates.io Documentation

Waker implementation using current thread token.

This is useful to work with futures without actually employing runtime

Usage

use core::{time, task};
use std::thread;

use thread_waker::waker;

fn my_future(waker: task::Waker) {
    thread::sleep(time::Duration::from_millis(250));
    waker.wake();
}

let waker = waker(thread::current());

for _ in 0..4 {
    let waker = waker.clone();
    thread::spawn(move || my_future(waker));
    thread::park();
}

println!("I'm done!");

lib.rs:

Waker implementation using current thread token.

This is useful to work with futures without actually employing runtime

Usage

use core::{time, task};
use std::thread;

use thread_waker::waker;

fn my_future(waker: task::Waker) {
    thread::sleep(time::Duration::from_millis(250));
    waker.wake();
}

let waker = waker(thread::current());

for _ in 0..4 {
    let waker = waker.clone();
    thread::spawn(move || my_future(waker));
    thread::park();
}

println!("I'm done!");

No runtime deps