[][src]Struct glib::MainContext

pub struct MainContext(_);

Methods

impl MainContext[src]

pub fn new() -> MainContext[src]

pub fn acquire(&self) -> bool[src]

pub fn dispatch(&self)[src]

pub fn is_owner(&self) -> bool[src]

pub fn iteration(&self, may_block: bool) -> bool[src]

pub fn pending(&self) -> bool[src]

pub fn pop_thread_default(&self)[src]

pub fn push_thread_default(&self)[src]

pub fn release(&self)[src]

pub fn wakeup(&self)[src]

pub fn default() -> MainContext[src]

pub fn get_thread_default() -> Option<MainContext>[src]

pub fn ref_thread_default() -> MainContext[src]

impl MainContext[src]

pub fn prepare(&self) -> (bool, i32)[src]

pub fn find_source_by_id(&self, source_id: &SourceId) -> Option<Source>[src]

pub fn invoke<F>(&self, func: F) where
    F: FnOnce() + Send + 'static, 
[src]

Invokes func on the main context.

pub fn invoke_with_priority<F>(&self, priority: Priority, func: F) where
    F: FnOnce() + Send + 'static, 
[src]

Invokes func on the main context with the given priority.

pub fn invoke_local<F>(&self, func: F) where
    F: FnOnce() + 'static, 
[src]

Invokes func on the main context.

Different to invoke(), this does not require func to be Send but can only be called from the thread that owns the main context.

This function panics if called from a different thread than the one that owns the main context.

pub fn invoke_local_with_priority<F>(&self, priority: Priority, func: F) where
    F: FnOnce() + 'static, 
[src]

Invokes func on the main context with the given priority.

Different to invoke_with_priority(), this does not require func to be Send but can only be called from the thread that owns the main context.

This function panics if called from a different thread than the one that owns the main context.

pub fn with_thread_default<R, F: Sized>(&self, func: F) -> R where
    F: FnOnce() -> R, 
[src]

Calls closure with context configured as the thread default one.

Thread default context is changed in panic-safe manner by calling push_thread_default before calling closure and pop_thread_default afterwards regardless of whether closure panicked or not.

impl MainContext[src]

pub fn channel<T>(priority: Priority) -> (Sender<T>, Receiver<T>)[src]

Creates a channel for a main context.

The Receiver has to be attached to a main context at a later time, together with a closure that will be called for every item sent to a Sender.

The Sender can be cloned and both the Sender and Receiver can be sent to different threads as long as the item type implements the Send trait.

When the last Sender is dropped the channel is removed from the main context. If the Receiver is dropped and not attached to a main context all sending to the Sender will fail.

The returned Sender behaves the same as std::sync::mpsc::Sender.

pub fn sync_channel<T>(
    priority: Priority,
    bound: usize
) -> (SyncSender<T>, Receiver<T>)
[src]

Creates a synchronous channel for a main context with a given bound on the capacity of the channel.

The Receiver has to be attached to a main context at a later time, together with a closure that will be called for every item sent to a SyncSender.

The SyncSender can be cloned and both the SyncSender and Receiver can be sent to different threads as long as the item type implements the Send trait.

When the last SyncSender is dropped the channel is removed from the main context. If the Receiver is dropped and not attached to a main context all sending to the SyncSender will fail.

The returned SyncSender behaves the same as std::sync::mpsc::SyncSender.

impl MainContext[src]

pub fn spawn<F: Future<Output = ()> + Send + 'static>(&self, f: F)[src]

Spawn a new infallible Future on the main context.

This can be called from any thread and will execute the future from the thread where main context is running, e.g. via a MainLoop.

pub fn spawn_local<F: Future<Output = ()> + 'static>(&self, f: F)[src]

Spawn a new infallible Future on the main context.

The given Future does not have to be Send.

This can be called only from the thread where the main context is running, e.g. from any other Future that is executed on this main context, or after calling push_thread_default or acquire on the main context.

pub fn spawn_with_priority<F: Future<Output = ()> + Send + 'static>(
    &self,
    priority: Priority,
    f: F
)
[src]

Spawn a new infallible Future on the main context, with a non-default priority.

This can be called from any thread and will execute the future from the thread where main context is running, e.g. via a MainLoop.

pub fn spawn_local_with_priority<F: Future<Output = ()> + 'static>(
    &self,
    priority: Priority,
    f: F
)
[src]

Spawn a new infallible Future on the main context, with a non-default priority.

The given Future does not have to be Send.

This can be called only from the thread where the main context is running, e.g. from any other Future that is executed on this main context, or after calling push_thread_default or acquire on the main context.

pub fn block_on<F: Future>(&self, f: F) -> F::Output[src]

Runs a new, infallible Future on the main context and block until it finished, returning the result of the Future.

The given Future does not have to be Send or 'static.

This must only be called if no MainLoop or anything else is running on this specific main context.

Trait Implementations

impl StaticType for MainContext[src]

impl PartialOrd<MainContext> for MainContext[src]

impl Eq for MainContext[src]

impl Sync for MainContext[src]

impl PartialEq<MainContext> for MainContext[src]

impl Send for MainContext[src]

impl Ord for MainContext[src]

fn max(self, other: Self) -> Self1.21.0[src]

Compares and returns the maximum of two values. Read more

fn min(self, other: Self) -> Self1.21.0[src]

Compares and returns the minimum of two values. Read more

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

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

Restrict a value to a certain interval. Read more

impl Default for MainContext[src]

impl Clone for MainContext[src]

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

Performs copy-assignment from source. Read more

impl Hash for MainContext[src]

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 Debug for MainContext[src]

impl LocalSpawn for MainContext[src]

fn status_local(&self) -> Result<(), SpawnError>[src]

Determines whether the executor is able to spawn new tasks. Read more

impl Spawn for MainContext[src]

fn status(&self) -> Result<(), SpawnError>[src]

Determines whether the executor is able to spawn new tasks. Read more

impl<'_> Spawn for &'_ MainContext[src]

Implementing Spawn for a reference of MainContext allows to convert it to a futures-0.1 Executor, using the futures-0.1 compatibility layer.

See https://rust-lang-nursery.github.io/futures-api-docs/0.3.0-alpha.16/src/futures_util/compat/executor.rs.html#85

fn status(&self) -> Result<(), SpawnError>[src]

Determines whether the executor is able to spawn new tasks. Read more

Auto Trait Implementations

impl Unpin for MainContext

impl UnwindSafe for MainContext

impl RefUnwindSafe for MainContext

Blanket Implementations

impl<'a, T> ToGlibContainerFromSlice<'a, *mut GList> for T where
    T: GlibPtrDefault + ToGlibPtr<'a, <T as GlibPtrDefault>::GlibType>, 
[src]

impl<'a, T> ToGlibContainerFromSlice<'a, *const GList> for T where
    T: GlibPtrDefault + ToGlibPtr<'a, <T as GlibPtrDefault>::GlibType>, 
[src]

impl<'a, T> ToGlibContainerFromSlice<'a, *mut GArray> for T where
    T: GlibPtrDefault + ToGlibPtr<'a, <T as GlibPtrDefault>::GlibType>, 
[src]

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

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

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

type Owned = T

The resulting type after obtaining ownership.

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

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

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.

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.

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

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

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

impl<Sp> LocalSpawnExt for Sp where
    Sp: LocalSpawn + ?Sized
[src]

fn spawn_local<Fut>(&mut self, future: Fut) -> Result<(), SpawnError> where
    Fut: Future<Output = ()> + 'static, 
[src]

Spawns a task that polls the given future with output () to completion. Read more

fn spawn_local_with_handle<Fut>(
    &mut self,
    future: Fut
) -> Result<RemoteHandle<<Fut as Future>::Output>, SpawnError> where
    Fut: Future + 'static, 
[src]

Spawns a task that polls the given future to completion and returns a future that resolves to the spawned future's output. Read more

impl<Sp> SpawnExt for Sp where
    Sp: Spawn + ?Sized
[src]

fn spawn<Fut>(&mut self, future: Fut) -> Result<(), SpawnError> where
    Fut: Future<Output = ()> + Send + 'static, 
[src]

Spawns a task that polls the given future with output () to completion. Read more

fn spawn_with_handle<Fut>(
    &mut self,
    future: Fut
) -> Result<RemoteHandle<<Fut as Future>::Output>, SpawnError> where
    Fut: Future + Send + 'static,
    <Fut as Future>::Output: Send
[src]

Spawns a task that polls the given future to completion and returns a future that resolves to the spawned future's output. Read more