[][src]Struct wayland_client::Proxy

pub struct Proxy<I: Interface> { /* fields omitted */ }

An handle to a wayland proxy

This represents a wayland object instantiated in your client session. Several handles to the same object can exist at a given time, and cloning them won't create a new protocol object, only clone the handle. The lifetime of the protocol object is not tied to the lifetime of these handles, but rather to sending or receiving destroying messages.

These handles are notably used to send requests to the server. To do you need to import the associated RequestsTrait trait from the module of this interface.

Methods

impl<I: Interface> Proxy<I>[src]

pub fn send(&self, msg: I::Request)[src]

Send a request through this object

Warning: This method is mostly intended to be used by code generated by wayland-scanner, and you should probably never need to use it directly, but rather use the appropriate RequestsTrait for your proxy.

This is the generic method to send requests.

If your request needs to create an object, use send_constructor.

pub fn send_constructor<J, F>(
    &self,
    msg: I::Request,
    implementor: F,
    version: Option<u32>
) -> Result<Proxy<J>, ()> where
    J: Interface,
    F: FnOnce(NewProxy<J>) -> Proxy<J>, 
[src]

Send a request creating an object through this object

Warning: This method is mostly intended to be used by code generated by wayland-scanner, and you should probably never need to use it directly, but rather use the appropriate RequestsTrait for your proxy.

This is the generic method to send requests that create objects

The slot in the message corresponding with the newly created object must have been filled by a placeholder object (see child_placeholder).

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

Check if the object associated with this proxy is still alive

Will return false if the object has been destroyed.

If the object is not managed by this library, this will always returns true.

pub fn version(&self) -> u32[src]

Retrieve the interface version of this wayland object instance

Returns 0 on dead objects

pub fn id(&self) -> u32[src]

Retrieve the object id of this wayland object

pub fn user_data<UD: 'static>(&self) -> Option<&UD>[src]

Access the arbitrary payload associated to this object

You need to specify the expected type of this payload, and this function will return None if either the types don't match or you are attempting to access a non Send + Sync user data from the wrong thread.

This value is associated to the Proxy when you implement it, and you cannot access it mutably afterwards. If you need interior mutability, you are responsible for using a Mutex or similar type to achieve it.

pub fn equals(&self, other: &Proxy<I>) -> bool[src]

Check if the other proxy refers to the same underlying wayland object

pub fn child<C: Interface>(&self) -> NewProxy<C>[src]

Create a new child object

Warning: This method is mostly intended to be used by code generated by wayland-scanner, and you should probably never need to use it directly, but rather use the appropriate RequestsTrait for your proxy.

This creates a new wayland object, considered as a child of this object. It will notably inherit its interface version.

The created object should immediately be implemented and sent in a request to the server, to keep the object list properly synchronized. Failure to do so will likely cause a protocol error.

pub fn anonymize(&self) -> Proxy<AnonymousObject>[src]

Creates a handle of this proxy with its actual type erased

pub fn make_wrapper(&self, queue: &QueueToken) -> Result<Proxy<I>, ()>[src]

Create a wrapper for this object for queue management

As assigning a proxy to an event queue can be a racy operation in contexts involving multiple thread, this provides a facility to do this safely.

The wrapper object created behaves like a regular Proxy, except that all objects created as the result of its requests will be assigned to the queue associated to the provided token, rather than the queue of their parent. This does not change the queue of the proxy itself.

pub fn child_placeholder<J: Interface>(&self) -> Proxy<J>[src]

Create a placeholder object, to be used with send_constructor

Warning: This method is mostly intended to be used by code generated by wayland-scanner, and you should probably never need to use it directly, but rather use the appropriate RequestsTrait for your proxy.

Trait Implementations

impl RequestsTrait for Proxy<WlDisplay>[src]

impl RequestsTrait for Proxy<WlRegistry>[src]

impl RequestsTrait for Proxy<WlCallback>[src]

impl RequestsTrait for Proxy<WlCompositor>[src]

impl RequestsTrait for Proxy<WlShmPool>[src]

impl RequestsTrait for Proxy<WlShm>[src]

impl RequestsTrait for Proxy<WlBuffer>[src]

impl RequestsTrait for Proxy<WlDataOffer>[src]

impl RequestsTrait for Proxy<WlDataSource>[src]

impl RequestsTrait for Proxy<WlDataDevice>[src]

impl RequestsTrait for Proxy<WlDataDeviceManager>[src]

impl RequestsTrait for Proxy<WlShell>[src]

impl RequestsTrait for Proxy<WlShellSurface>[src]

impl RequestsTrait for Proxy<WlSurface>[src]

impl RequestsTrait for Proxy<WlSeat>[src]

impl RequestsTrait for Proxy<WlPointer>[src]

impl RequestsTrait for Proxy<WlKeyboard>[src]

impl RequestsTrait for Proxy<WlTouch>[src]

impl RequestsTrait for Proxy<WlOutput>[src]

impl RequestsTrait for Proxy<WlRegion>[src]

impl RequestsTrait for Proxy<WlSubcompositor>[src]

impl RequestsTrait for Proxy<WlSubsurface>[src]

impl<I: Interface> Eq for Proxy<I>[src]

impl<I: Interface> PartialEq<Proxy<I>> for Proxy<I>[src]

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

This method tests for !=.

impl<I: Interface> Clone for Proxy<I>[src]

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

Performs copy-assignment from source. Read more

Auto Trait Implementations

impl<I> Send for Proxy<I> where
    I: Sync

impl<I> Sync for Proxy<I> where
    I: Sync

Blanket Implementations

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> BorrowMut<T> for T where
    T: ?Sized
[src]

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

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

impl<T> Downcast for T where
    T: Any
[src]