Struct wayland_server::Display

source ·
pub struct Display<State: 'static> { /* private fields */ }
Expand description

The Wayland display

This struct is the core of your Wayland compositor. You’ll use it in your event loop to drive the protocol processing of all your clients. All other interactions with the protocol itself are done through the DisplayHandle struct, on which the State type parameter is erased for convenience.

§Usage

The main loop of a Wayland compositor generally needs to wait on several sources of events, using tools like epoll (on Linux). The Wayland display can be integrated in this mechanism by getting the file descriptor as from .backend().poll_fd() and invoking the dispatch_clients() method whenever it becomes readable.

To ensure all clients receive the events your compositor sends them, you also need to regularly invoke the flush_clients() method, which will write the outgoing buffers into the sockets.

Implementations§

source§

impl<State: 'static> Display<State>

source

pub fn new() -> Result<Display<State>, InitError>

Create a new Wayland display

Can only fail if both the server_system and dlopen features of wayland-backend were enabled, and the libwayland-server.so library could not be found.

source

pub fn handle(&self) -> DisplayHandle

Retrieve a DisplayHandle for this Display.

This is the type with which all of your interactions with the Wayland protocol are done.

source

pub fn dispatch_clients(&mut self, state: &mut State) -> Result<usize>

Dispatch all requests received from clients to their respective callbacks.

The state argument is the main state of your compositor, which will be accessible from most of your callbacks.

source

pub fn flush_clients(&mut self) -> Result<()>

Flush outgoing buffers into their respective sockets.

source

pub fn backend(&mut self) -> &mut Backend<State>

Access the underlying Backend of this Display

Trait Implementations§

source§

impl<State> AsFd for Display<State>

source§

fn as_fd(&self) -> BorrowedFd<'_>

Provides fd from Backend::poll_fd for polling.

source§

impl<State: Debug + 'static> Debug for Display<State>

source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<State> RefUnwindSafe for Display<State>

§

impl<State> Send for Display<State>

§

impl<State> Sync for Display<State>

§

impl<State> Unpin for Display<State>

§

impl<State> UnwindSafe for Display<State>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

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

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

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

The type returned in the event of a conversion error.
source§

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

Performs the conversion.