pub struct Subsurface<S: Shell>(_);
Expand description

Implementation of the wl_subsurface interface

Trait Implementations§

source§

impl<S: Shell> Debug for Subsurface<S>

source§

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

Formats the value using the given formatter. Read more
source§

impl<S: Shell> MonoObject for Subsurface<S>

§

type SingletonState = ()

A singleton state associated with the object type. This state is associated with the type, so there is only one instance of the state for all objects of the same type. The lifetime of this state is managed by the object store, and it will be dropped when the last object of the type is dropped.
source§

const INTERFACE: &'static str = wl_subsurface::NAME

The wayland interface implemented by this object.
source§

fn new_singleton_state() -> Self::SingletonState

Create a new instance of the singleton state.
source§

impl<Ctx: Client, S: Shell> Object<Ctx> for Subsurface<S>where Ctx::ServerContext: HasShell<Shell = S>,

§

type Request<'a> where Ctx: 'a = Request

The type of wayland messages that this object can receive. This is what the dispatch method accepts.
§

type Error = Error

Error returned by the dispatch method.
§

type Fut<'a> where Ctx: 'a = impl Future<Output = (Result<(), <Subsurface<S> as Object<Ctx>>::Error>, usize, usize)> + 'a

The future type returned by the dispatch method.
source§

fn dispatch<'a>( ctx: &'a mut Ctx, object_id: u32, msg: Self::Request<'a> ) -> Self::Fut<'a>

Dispatch a wayland request to this object. Returns a future, that resolves to (Result, usize, usize), which are the result of the request, the number of bytes and file descriptors in the request, respectively.
source§

fn on_disconnect( &mut self, _server_ctx: &mut <Ctx as Client>::ServerContext, _state: &mut (dyn Any + 'static) )

A function that will be called when the client disconnects. It should free up allocated resources if any. This function only gets reference to the server context, because: Read more
source§

impl<Ctx: Client, S: Shell> RequestDispatch<Ctx> for Subsurface<S>where Ctx::ServerContext: HasShell<Shell = S>,

§

type Error = Error

§

type DestroyFut<'a> where Ctx: 'a = impl Future<Output = Result<(), <Subsurface<S> as RequestDispatch<Ctx>>::Error>> + 'a

Type of future returned by destroy
§

type PlaceAboveFut<'a> where Ctx: 'a = impl Future<Output = Result<(), <Subsurface<S> as RequestDispatch<Ctx>>::Error>> + 'a

Type of future returned by place_above
§

type PlaceBelowFut<'a> where Ctx: 'a = impl Future<Output = Result<(), <Subsurface<S> as RequestDispatch<Ctx>>::Error>> + 'a

Type of future returned by place_below
§

type SetDesyncFut<'a> where Ctx: 'a = impl Future<Output = Result<(), <Subsurface<S> as RequestDispatch<Ctx>>::Error>> + 'a

Type of future returned by set_desync
§

type SetPositionFut<'a> where Ctx: 'a = impl Future<Output = Result<(), <Subsurface<S> as RequestDispatch<Ctx>>::Error>> + 'a

Type of future returned by set_position
§

type SetSyncFut<'a> where Ctx: 'a = impl Future<Output = Result<(), <Subsurface<S> as RequestDispatch<Ctx>>::Error>> + 'a

Type of future returned by set_sync
source§

fn set_sync(_ctx: &mut Ctx, object_id: u32) -> Self::SetSyncFut<'_>

set sub-surface to synchronized mode Read more
source§

fn set_desync(_ctx: &mut Ctx, object_id: u32) -> Self::SetDesyncFut<'_>

set sub-surface to desynchronized mode Read more
source§

fn destroy(ctx: &mut Ctx, object_id: u32) -> Self::DestroyFut<'_>

remove sub-surface interface Read more
source§

fn place_above( _ctx: &mut Ctx, object_id: u32, sibling: Object ) -> Self::PlaceAboveFut<'_>

restack the sub-surface Read more
source§

fn place_below( _ctx: &mut Ctx, object_id: u32, sibling: Object ) -> Self::PlaceBelowFut<'_>

restack the sub-surface Read more
source§

fn set_position( ctx: &mut Ctx, object_id: u32, x: i32, y: i32 ) -> Self::SetPositionFut<'_>

reposition the sub-surface Read more

Auto Trait Implementations§

§

impl<S> !RefUnwindSafe for Subsurface<S>

§

impl<S> !Send for Subsurface<S>

§

impl<S> !Sync for Subsurface<S>

§

impl<S> Unpin for Subsurface<S>

§

impl<S> !UnwindSafe for Subsurface<S>

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Az for T

source§

fn az<Dst>(self) -> Dstwhere T: Cast<Dst>,

Casts the value.
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<Src, Dst> CastFrom<Src> for Dstwhere Src: Cast<Dst>,

source§

fn cast_from(src: Src) -> Dst

Casts the value.
source§

impl<T> CheckedAs for T

source§

fn checked_as<Dst>(self) -> Option<Dst>where T: CheckedCast<Dst>,

Casts the value.
source§

impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere Src: CheckedCast<Dst>,

source§

fn checked_cast_from(src: Src) -> Option<Dst>

Casts the value.
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

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

const: unstable · 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<Src, Dst> LosslessTryInto<Dst> for Srcwhere Dst: LosslessTryFrom<Src>,

source§

fn lossless_try_into(self) -> Option<Dst>

Performs the conversion.
source§

impl<Src, Dst> LossyInto<Dst> for Srcwhere Dst: LossyFrom<Src>,

source§

fn lossy_into(self) -> Dst

Performs the conversion.
source§

impl<T> OverflowingAs for T

source§

fn overflowing_as<Dst>(self) -> (Dst, bool)where T: OverflowingCast<Dst>,

Casts the value.
source§

impl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere Src: OverflowingCast<Dst>,

source§

fn overflowing_cast_from(src: Src) -> (Dst, bool)

Casts the value.
source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> SaturatingAs for T

source§

fn saturating_as<Dst>(self) -> Dstwhere T: SaturatingCast<Dst>,

Casts the value.
source§

impl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere Src: SaturatingCast<Dst>,

source§

fn saturating_cast_from(src: Src) -> Dst

Casts the value.
source§

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

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

impl<T> UnwrappedAs for T

source§

fn unwrapped_as<Dst>(self) -> Dstwhere T: UnwrappedCast<Dst>,

Casts the value.
source§

impl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere Src: UnwrappedCast<Dst>,

source§

fn unwrapped_cast_from(src: Src) -> Dst

Casts the value.
source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

impl<T> WrappingAs for T

source§

fn wrapping_as<Dst>(self) -> Dstwhere T: WrappingCast<Dst>,

Casts the value.
source§

impl<Src, Dst> WrappingCastFrom<Src> for Dstwhere Src: WrappingCast<Dst>,

source§

fn wrapping_cast_from(src: Src) -> Dst

Casts the value.