Flowync

Crates.io Flowync documentation CI

Quick Example

```rust use flowync::Flower;

fn main() { let flower = Flower::::new(1); std::thread::spawn({ let handle = flower.handle(); move || { for i in 0..10 { // Send current value through channel, will block the spawned thread // until the option value successfully being polled in the main thread. handle.send(i); // or handle.send_async(i).await; can be used from any multithreaded async runtime, // it won't block the other async operations.

            // // Return error if the job is failure, for example:
            // if i >= 3 {
            //    return handle.err("Err".to_string());
            // }
        }
        // And return ok if the job successfully completed.
        return handle.ok("Ok".to_string());
    }
});

let mut exit = false;

loop {
    // Instead of polling the mutex over and over,
    // the fn will be activated automatically if the handle sending or return a value
    // and will deactivate itself if the result value successfully received.
    // Note: this fn is non-blocking (won't block the current thread).
    flower.try_recv(
        |value| {
            println!("{}", value);
        },
        |result| {
            match result {
                Ok(value) => {
                    println!("{}", value);
                }
                Err(e) => {
                    println!("{}", e);
                }
            }
            exit = true;
        },
    );

    if exit {
        break;
    }
}

} ```

More examples

can be found here here