pub struct MainContext { /* private fields */ }Implementations§
§impl MainContext
impl MainContext
pub fn as_ptr(&self) -> *mut GMainContext
pub fn as_ptr(&self) -> *mut GMainContext
Return the inner pointer to the underlying C value.
§impl MainContext
impl MainContext
pub fn new() -> MainContext
pub fn dispatch(&self)
pub fn is_owner(&self) -> bool
pub fn iteration(&self, may_block: bool) -> bool
pub fn pending(&self) -> bool
pub fn wakeup(&self)
pub fn default() -> MainContext
pub fn thread_default() -> Option<MainContext>
pub fn ref_thread_default() -> MainContext
§impl MainContext
impl MainContext
pub fn prepare(&self) -> (bool, i32)
pub fn find_source_by_id(&self, source_id: &SourceId) -> Option<Source>
pub fn invoke<F>(&self, func: F)where
F: FnOnce() + Send + 'static,
pub fn invoke<F>(&self, func: F)where F: FnOnce() + Send + 'static,
Invokes func on the main context.
If the current thread is the owner of the main context or the main context currently has no
owner then func will be called directly from inside this function. If this behaviour is
not desired and func should always be called asynchronously then use MainContext::spawn
glib::idle_add instead.
pub fn invoke_with_priority<F>(&self, priority: Priority, func: F)where
F: FnOnce() + Send + 'static,
pub fn invoke_with_priority<F>(&self, priority: Priority, func: F)where F: FnOnce() + Send + 'static,
Invokes func on the main context with the given priority.
If the current thread is the owner of the main context or the main context currently has no
owner then func will be called directly from inside this function. If this behaviour is
not desired and func should always be called asynchronously then use MainContext::spawn
glib::idle_add instead.
pub fn invoke_local<F>(&self, func: F)where
F: FnOnce() + 'static,
pub fn invoke_local<F>(&self, func: F)where F: FnOnce() + 'static,
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.
Note that this effectively means that func is called directly from inside this function
or otherwise panics immediately. If this behaviour is not desired and func should always
be called asynchronously then use MainContext::spawn_local
glib::idle_add_local instead.
pub fn invoke_local_with_priority<F>(&self, _priority: Priority, func: F)where
F: FnOnce() + 'static,
pub fn invoke_local_with_priority<F>(&self, _priority: Priority, func: F)where F: FnOnce() + 'static,
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.
Note that this effectively means that func is called directly from inside this function
or otherwise panics immediately. If this behaviour is not desired and func should always
be called asynchronously then use MainContext::spawn_local
glib::idle_add_local instead.
pub fn with_thread_default<R, F>(&self, func: F) -> Result<R, BoolError>where
F: FnOnce() -> R,
pub fn with_thread_default<R, F>(&self, func: F) -> Result<R, BoolError>where F: FnOnce() -> R,
Call closure with the main context configured as the thread default one.
The thread default main context is changed in a panic-safe manner before calling func and
released again afterwards regardless of whether closure panicked or not.
This will fail if the main context is owned already by another thread.
pub fn acquire(&self) -> Result<MainContextAcquireGuard<'_>, BoolError>
pub fn acquire(&self) -> Result<MainContextAcquireGuard<'_>, BoolError>
Acquire ownership of the main context.
Ownership will automatically be released again once the returned acquire guard is dropped.
This will fail if the main context is owned already by another thread.
§impl MainContext
impl MainContext
pub fn channel<T>(priority: Priority) -> (Sender<T>, Receiver<T>)
pub fn channel<T>(priority: Priority) -> (Sender<T>, Receiver<T>)
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>)
pub fn sync_channel<T>( priority: Priority, bound: usize ) -> (SyncSender<T>, Receiver<T>)
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
impl MainContext
pub fn spawn<F>(&self, f: F) -> SourceIdwhere
F: Future<Output = ()> + Send + 'static,
pub fn spawn<F>(&self, f: F) -> SourceIdwhere F: Future<Output = ()> + Send + 'static,
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>(&self, f: F) -> SourceIdwhere
F: Future<Output = ()> + 'static,
pub fn spawn_local<F>(&self, f: F) -> SourceIdwhere F: Future<Output = ()> + 'static,
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
with_thread_default or acquire on the main context.
pub fn spawn_with_priority<F>(&self, priority: Priority, f: F) -> SourceIdwhere
F: Future<Output = ()> + Send + 'static,
pub fn spawn_with_priority<F>(&self, priority: Priority, f: F) -> SourceIdwhere F: Future<Output = ()> + Send + 'static,
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>(&self, priority: Priority, f: F) -> SourceIdwhere
F: Future<Output = ()> + 'static,
pub fn spawn_local_with_priority<F>(&self, priority: Priority, f: F) -> SourceIdwhere F: Future<Output = ()> + 'static,
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
with_thread_default or acquire on the main context.
pub fn block_on<F>(&self, f: F) -> <F as Future>::Outputwhere
F: Future,
pub fn block_on<F>(&self, f: F) -> <F as Future>::Outputwhere F: Future,
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 Clone for MainContext
impl Clone for MainContext
§fn clone(&self) -> MainContext
fn clone(&self) -> MainContext
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more§impl Debug for MainContext
impl Debug for MainContext
§impl Default for MainContext
impl Default for MainContext
§fn default() -> MainContext
fn default() -> MainContext
§impl Hash for MainContext
impl Hash for MainContext
§impl LocalSpawn for MainContext
impl LocalSpawn for MainContext
§impl Ord for MainContext
impl Ord for MainContext
§impl PartialEq<MainContext> for MainContext
impl PartialEq<MainContext> for MainContext
§fn eq(&self, other: &MainContext) -> bool
fn eq(&self, other: &MainContext) -> bool
self and other values to be equal, and is used
by ==.§impl PartialOrd<MainContext> for MainContext
impl PartialOrd<MainContext> for MainContext
§fn partial_cmp(&self, other: &MainContext) -> Option<Ordering>
fn partial_cmp(&self, other: &MainContext) -> Option<Ordering>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self and other) and is used by the <=
operator. Read more§impl Spawn for MainContext
impl Spawn for MainContext
§impl StaticType for MainContext
impl StaticType for MainContext
§fn static_type() -> Type
fn static_type() -> Type
Self.impl Eq for MainContext
impl Send for MainContext
impl StructuralEq for MainContext
impl StructuralPartialEq for MainContext
impl Sync for MainContext
Auto Trait Implementations§
Blanket Implementations§
§impl<T> FromGlibContainerAsVec<<T as GlibPtrDefault>::GlibType, *const GList> for Twhere
T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
impl<T> FromGlibContainerAsVec<<T as GlibPtrDefault>::GlibType, *const GList> for Twhere T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
§impl<T> FromGlibContainerAsVec<<T as GlibPtrDefault>::GlibType, *const GPtrArray> for Twhere
T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
impl<T> FromGlibContainerAsVec<<T as GlibPtrDefault>::GlibType, *const GPtrArray> for Twhere T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
§impl<T> FromGlibContainerAsVec<<T as GlibPtrDefault>::GlibType, *const GSList> for Twhere
T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
impl<T> FromGlibContainerAsVec<<T as GlibPtrDefault>::GlibType, *const GSList> for Twhere T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
§impl<T> FromGlibContainerAsVec<<T as GlibPtrDefault>::GlibType, *mut GList> for Twhere
T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
impl<T> FromGlibContainerAsVec<<T as GlibPtrDefault>::GlibType, *mut GList> for Twhere T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
§impl<T> FromGlibContainerAsVec<<T as GlibPtrDefault>::GlibType, *mut GPtrArray> for Twhere
T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
impl<T> FromGlibContainerAsVec<<T as GlibPtrDefault>::GlibType, *mut GPtrArray> for Twhere T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
§impl<T> FromGlibContainerAsVec<<T as GlibPtrDefault>::GlibType, *mut GSList> for Twhere
T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
impl<T> FromGlibContainerAsVec<<T as GlibPtrDefault>::GlibType, *mut GSList> for Twhere T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
§impl<T> FromGlibPtrArrayContainerAsVec<<T as GlibPtrDefault>::GlibType, *const GList> for Twhere
T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
impl<T> FromGlibPtrArrayContainerAsVec<<T as GlibPtrDefault>::GlibType, *const GList> for Twhere T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
§impl<T> FromGlibPtrArrayContainerAsVec<<T as GlibPtrDefault>::GlibType, *const GPtrArray> for Twhere
T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
impl<T> FromGlibPtrArrayContainerAsVec<<T as GlibPtrDefault>::GlibType, *const GPtrArray> for Twhere T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
§impl<T> FromGlibPtrArrayContainerAsVec<<T as GlibPtrDefault>::GlibType, *const GSList> for Twhere
T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
impl<T> FromGlibPtrArrayContainerAsVec<<T as GlibPtrDefault>::GlibType, *const GSList> for Twhere T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
§impl<T> FromGlibPtrArrayContainerAsVec<<T as GlibPtrDefault>::GlibType, *mut GList> for Twhere
T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
impl<T> FromGlibPtrArrayContainerAsVec<<T as GlibPtrDefault>::GlibType, *mut GList> for Twhere T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
§impl<T> FromGlibPtrArrayContainerAsVec<<T as GlibPtrDefault>::GlibType, *mut GPtrArray> for Twhere
T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
impl<T> FromGlibPtrArrayContainerAsVec<<T as GlibPtrDefault>::GlibType, *mut GPtrArray> for Twhere T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
§impl<T> FromGlibPtrArrayContainerAsVec<<T as GlibPtrDefault>::GlibType, *mut GSList> for Twhere
T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
impl<T> FromGlibPtrArrayContainerAsVec<<T as GlibPtrDefault>::GlibType, *mut GSList> for Twhere T: GlibPtrDefault + FromGlibPtrNone<<T as GlibPtrDefault>::GlibType> + FromGlibPtrFull<<T as GlibPtrDefault>::GlibType>,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> RoundFrom<T> for T
impl<T> RoundFrom<T> for T
§fn round_from(x: T) -> T
fn round_from(x: T) -> T
§impl<T, U> RoundInto<U> for Twhere
U: RoundFrom<T>,
impl<T, U> RoundInto<U> for Twhere U: RoundFrom<T>,
§fn round_into(self) -> U
fn round_into(self) -> U
§impl<T> StaticTypeExt for Twhere
T: StaticType,
impl<T> StaticTypeExt for Twhere T: StaticType,
§fn ensure_type()
fn ensure_type()
§impl<T> ToClosureReturnValue for Twhere
T: ToValue,
impl<T> ToClosureReturnValue for Twhere T: ToValue,
fn to_closure_return_value(&self) -> Option<Value>
§impl<T> ToSendValue for Twhere
T: Send + ToValue + ?Sized,
impl<T> ToSendValue for Twhere T: Send + ToValue + ?Sized,
§fn to_send_value(&self) -> SendValue
fn to_send_value(&self) -> SendValue
SendValue clone of self.