[−][src]Struct wayland_client::GlobalManager
An utility to manage global objects
This utility provides an implemenation for the registry that track the list of globals for you, as well as utilities to bind them.
Implementations
impl GlobalManager
[src]
pub fn new(display: &Attached<WlDisplay>) -> GlobalManager
[src]
Create a global manager handling a registry
You need to provide an attached handle of the Waland display, and the global manager will be managed by the associated event queue.
pub fn new_with_cb<F>(
display: &Attached<WlDisplay>,
callback: F
) -> GlobalManager where
F: FnMut(GlobalEvent, Attached<WlRegistry>, DispatchData) + 'static,
[src]
display: &Attached<WlDisplay>,
callback: F
) -> GlobalManager where
F: FnMut(GlobalEvent, Attached<WlRegistry>, DispatchData) + 'static,
Create a global manager handling a registry with a callback
This global manager will track globals as a simple one, but will also forward the registry events to your callback.
This can be used if you want to handle specially certain globals, but want to use the default mechanism for the rest.
You need to provide an attached handle of the Waland display, and the global manager will be managed by the associated event queue.
pub fn instantiate_exact<I>(&self, version: u32) -> Result<Main<I>, GlobalError> where
I: Interface + AsRef<Proxy<I>> + From<Proxy<I>>,
[src]
I: Interface + AsRef<Proxy<I>> + From<Proxy<I>>,
Instantiate a global with a specific version
Meaning of requests and events can change depending on the object version you use,
as such unless you specifically want to support several versions of a protocol, it is
recommended to use this method with an hardcoded value for the version (the one you'll
use a as reference for your implementation). Notably you should not use I::VERSION
as a version, as this value can change when the protocol files are updated.
This method is only appropriate for globals that are expected to
not exist with multiplicity (such as wl_compositor
or wl_shm
),
as it will always bind the first one that was advertized.
pub fn instantiate_range<I>(
&self,
min_version: u32,
max_version: u32
) -> Result<Main<I>, GlobalError> where
I: Interface + AsRef<Proxy<I>> + From<Proxy<I>>,
[src]
&self,
min_version: u32,
max_version: u32
) -> Result<Main<I>, GlobalError> where
I: Interface + AsRef<Proxy<I>> + From<Proxy<I>>,
Instantiate a global from a version range
If you want to support several versions of a particular global, this method allows you to
specify a range of versions that you accept. It'll bind the highest possible version that
is between min_version
and max_version
inclusive, and return an error if the highest
version supported by the compositor is lower than min_version
. As for
instantiate_exact
, you should not use I::VERSION
here: the versions your code support
do not change when the protocol files are updated.
When trying to support several versions of a protocol, you can check which version has
actually been used on any object using the Proxy::version()
method.
As instantiate_exact
, it should only be used for singleton globals, for the same reasons.
pub fn list(&self) -> Vec<(u32, String, u32)>
[src]
Retrieve the list of currently known globals
Trait Implementations
impl Clone for GlobalManager
[src]
fn clone(&self) -> GlobalManager
[src]
fn clone_from(&mut self, source: &Self)
1.0.0[src]
Auto Trait Implementations
impl !RefUnwindSafe for GlobalManager
impl !Send for GlobalManager
impl !Sync for GlobalManager
impl Unpin for GlobalManager
impl !UnwindSafe for GlobalManager
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> Downcast for T where
T: Any,
[src]
T: Any,
fn into_any(self: Box<T>) -> Box<dyn Any + 'static>
[src]
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
[src]
fn as_any(&self) -> &(dyn Any + 'static)
[src]
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
[src]
impl<T> DowncastSync for T where
T: Send + Sync + Any,
[src]
T: Send + Sync + Any,
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
fn to_owned(&self) -> T
[src]
fn clone_into(&self, target: &mut T)
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,