pub struct Flower<SOME, OK> where
    SOME: Clone + Send + Sync + 'static,
    OK: Clone + Send + Sync + 'static, 
{ /* private fields */ }
Expand description

Flow loosely and gracefully.

Where:

SOME: type of sender (channel) value

OK: type of Ok value of the Result (Result<‘OK’, String>, and Err value always return String)

Quick Example:

use flowync::Flower;

fn main() {
    let flower = Flower::<i32, String>::new(1);
    std::thread::spawn({
        let handle = flower.handle();
        // Activate
        handle.activate();
        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,
                
                // // 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).
        if flower.is_active() {
            flower.try_recv(|channel| {
                if let Some(value) = channel {
                    println!("{}", value);
                }
            }).on_complete(|result| match result {
                Ok(value) => println!("{}", value),
                Err(err_msg) => println!("{}", err_msg),
            });
        }

        if exit {
            break;
        }
    }
}

Implementations

Get ID of the flower.

Get handle of the flower.

Cancel current flower handle.

will do nothing if not explicitly configured.

Check if the flower is canceled

Check if the current flower is active

Check if result value of the flower is ready

Check if channel value of the flower is present

Try receive the flower channel value

Process the flower result

Trait Implementations

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

Formats the value using the given formatter. Read more

Executes the destructor for this type. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The resulting type after obtaining ownership.

Creates owned data from borrowed data, usually by cloning. Read more

🔬 This is a nightly-only experimental API. (toowned_clone_into)

Uses borrowed data to replace owned data, usually by cloning. Read more

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.