Struct gstreamer::promise::Promise[][src]

pub struct Promise(_);
This is supported on crate feature v1_14 only.

The crate::Promise object implements the container for values that may be available later. i.e. a Future or a Promise in https://en.wikipedia.org/wiki/Futures_and_promises. As with all Future/Promise-like functionality, there is the concept of the producer of the value and the consumer of the value.

A crate::Promise is created with Self::new() by the consumer and passed to the producer to avoid thread safety issues with the change callback. A crate::Promise can be replied to with a value (or an error) by the producer with Self::reply(). The exact value returned is defined by the API contract of the producer and None may be a valid reply. Self::interrupt() is for the consumer to indicate to the producer that the value is not needed anymore and producing that value can stop. The crate::PromiseResult::Expired (XXX: @-reference does not belong to Promise!) state set by a call to Self::expire() indicates to the consumer that a value will never be produced and is intended to be called by a third party that implements some notion of message handling such as crate::Bus. A callback can also be installed at crate::Promise creation for result changes with [Self::new_with_change_func()]. The change callback can be used to chain GstPromises’s together as in the following example.

const GstStructure *reply;
GstPromise *p;
if (gst_promise_wait (promise) != GST_PROMISE_RESULT_REPLIED)
  return; // interrupted or expired value
reply = gst_promise_get_reply (promise);
if (error in reply)
  return; // propagate error
p = gst_promise_new_with_change_func (another_promise_change_func, user_data, notify);
pass p to promise-using API

Each crate::Promise starts out with a crate::PromiseResult of crate::PromiseResult::Pending and only ever transitions once into one of the other crate::PromiseResult’s.

In order to support multi-threaded code, Self::reply(), Self::interrupt() and Self::expire() may all be from different threads with some restrictions and the final result of the promise is whichever call is made first. There are two restrictions on ordering:

  1. That Self::reply() and Self::interrupt() cannot be called after Self::expire()
  2. That Self::reply() and Self::interrupt() cannot be called twice.

The change function set with [Self::new_with_change_func()] is called directly from either the Self::reply(), Self::interrupt() or Self::expire() and can be called from an arbitrary thread. crate::Promise using APIs can restrict this to a single thread or a subset of threads but that is entirely up to the API that uses crate::Promise.

Implementations

impl Promise[src]

pub fn new() -> Promise[src]

pub fn with_change_func<F>(func: F) -> Promise where
    F: FnOnce(Result<Option<&StructureRef>, PromiseError>) + Send + 'static, 
[src]

pub fn new_future() -> (Self, PromiseFuture)[src]

pub fn expire(&self)[src]

Expire a self. This will wake up any waiters with crate::PromiseResult::Expired. Called by a message loop when the parent message is handled and/or destroyed (possibly unanswered).

pub fn get_reply(&self) -> Option<&StructureRef>[src]

Retrieve the reply set on self. self must be in crate::PromiseResult::Replied and the returned structure is owned by self

Returns

The reply set on self

pub fn interrupt(&self)[src]

Interrupt waiting for a self. This will wake up any waiters with crate::PromiseResult::Interrupted. Called when the consumer does not want the value produced anymore.

pub fn reply(&self, s: Option<Structure>)[src]

Set a reply on self. This will wake up any waiters with crate::PromiseResult::Replied. Called by the producer of the value to indicate success (or failure).

If self has already been interrupted by the consumer, then this reply is not visible to the consumer.

s

a crate::Structure with the the reply contents

pub fn wait(&self) -> PromiseResult[src]

Wait for self to move out of the crate::PromiseResult::Pending state. If self is not in crate::PromiseResult::Pending then it will return immediately with the current result.

Returns

the result of the promise

Trait Implementations

impl Clone for Promise[src]

fn clone(&self) -> Promise[src]

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

impl Debug for Promise[src]

fn fmt(&self, f: &mut Formatter<'_>) -> Result[src]

Formats the value using the given formatter. Read more

impl Default for Promise[src]

fn default() -> Self[src]

Returns the “default value” for a type. Read more

impl Hash for Promise[src]

fn hash<__H: Hasher>(&self, state: &mut __H)[src]

Feeds this value into the given Hasher. Read more

fn hash_slice<H>(data: &[Self], state: &mut H) where
    H: Hasher
1.3.0[src]

Feeds a slice of this type into the given Hasher. Read more

impl Ord for Promise[src]

fn cmp(&self, other: &Promise) -> Ordering[src]

This method returns an Ordering between self and other. Read more

#[must_use]
fn max(self, other: Self) -> Self
1.21.0[src]

Compares and returns the maximum of two values. Read more

#[must_use]
fn min(self, other: Self) -> Self
1.21.0[src]

Compares and returns the minimum of two values. Read more

#[must_use]
fn clamp(self, min: Self, max: Self) -> Self
1.50.0[src]

Restrict a value to a certain interval. Read more

impl PartialEq<Promise> for Promise[src]

fn eq(&self, other: &Promise) -> bool[src]

This method tests for self and other values to be equal, and is used by ==. Read more

fn ne(&self, other: &Promise) -> bool[src]

This method tests for !=.

impl PartialOrd<Promise> for Promise[src]

fn partial_cmp(&self, other: &Promise) -> Option<Ordering>[src]

This method returns an ordering between self and other values if one exists. Read more

#[must_use]
fn lt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than (for self and other) and is used by the < operator. Read more

#[must_use]
fn le(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more

#[must_use]
fn gt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than (for self and other) and is used by the > operator. Read more

#[must_use]
fn ge(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more

impl StaticType for Promise[src]

fn static_type() -> Type[src]

Returns the type identifier of Self.

impl Eq for Promise[src]

impl Send for Promise[src]

impl StructuralEq for Promise[src]

impl StructuralPartialEq for Promise[src]

impl Sync for Promise[src]

Auto Trait Implementations

impl RefUnwindSafe for Promise

impl Unpin for Promise

impl UnwindSafe for Promise

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

pub fn to_owned(&self) -> T[src]

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

pub fn clone_into(&self, target: &mut T)[src]

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

recently added

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

impl<T> ToSendValue for T where
    T: Send + ToValue + ?Sized
[src]

pub fn to_send_value(&self) -> SendValue[src]

Returns a SendValue clone of self.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]

Performs the conversion.

impl<'a, T, C> FromValueOptional<'a> for T where
    C: ValueTypeChecker<Error = ValueTypeMismatchOrNoneError>,
    T: FromValue<'a, Checker = C>, 
[src]