#promise #future #async

pinky-swear

Futures and async/await-ready Promises

37 stable releases (6 major)

6.2.0 Nov 14, 2023
6.1.0 Jan 30, 2022
5.2.1 Jan 4, 2022
5.2.0 Dec 30, 2021
0.4.2 Oct 31, 2019

#307 in Asynchronous

Download history 39112/week @ 2024-10-20 33045/week @ 2024-10-27 36501/week @ 2024-11-03 36455/week @ 2024-11-10 37175/week @ 2024-11-17 33990/week @ 2024-11-24 34353/week @ 2024-12-01 39914/week @ 2024-12-08 33865/week @ 2024-12-15 13182/week @ 2024-12-22 15111/week @ 2024-12-29 32607/week @ 2025-01-05 38327/week @ 2025-01-12 32395/week @ 2025-01-19 40836/week @ 2025-01-26 43119/week @ 2025-02-02

156,168 downloads per month
Used in 89 crates (3 directly)

BSD-2-Clause

11KB
192 lines

Simple promise library compatible with std::future and async/await

API Docs Build status Downloads

Example

Create a promise and wait for the result while computing the result in another thread

use pinky_swear::{Pinky, PinkySwear};
use std::{thread, time::Duration};

fn compute(pinky: Pinky<Result<u32, ()>>) {
    thread::sleep(Duration::from_millis(1000));
    pinky.swear(Ok(42));
}

fn main() {
    let (promise, pinky) = PinkySwear::new();
    thread::spawn(move || {
        compute(pinky);
    });
    assert_eq!(promise.wait(), Ok(42));
}

lib.rs:

Simple promise library compatible with std::future and async/await

Example

Create a promise and wait for the result while computing the result in another thread

use pinky_swear::{Pinky, PinkySwear};
use std::{thread, time::Duration};

fn compute(pinky: Pinky<Result<u32, ()>>) {
    thread::sleep(Duration::from_millis(1000));
    pinky.swear(Ok(42));
}

fn main() {
    let (promise, pinky) = PinkySwear::new();
    thread::spawn(move || {
        compute(pinky);
    });
    assert_eq!(promise.wait(), Ok(42));
}

Dependencies

~0.9–5.5MB
~21K SLoC