x11rb::protocol::sync

Struct FenceWrapper

Source
pub struct FenceWrapper<C: RequestConnection>(/* private fields */);
Expand description

A RAII-like wrapper around a Fence.

Instances of this struct represent a Fence that is freed in Drop.

Any errors during Drop are silently ignored. Most likely an error here means that your X11 connection is broken and later requests will also fail.

Implementations§

Source§

impl<C: RequestConnection> FenceWrapper<C>

Source

pub fn for_fence(conn: C, id: Fence) -> Self

Assume ownership of the given resource and destroy it in Drop.

Source

pub fn fence(&self) -> Fence

Get the XID of the wrapped resource

Source

pub fn into_fence(self) -> Fence

Assume ownership of the XID of the wrapped resource

This function destroys this wrapper without freeing the underlying resource.

Source§

impl<'c, C: X11Connection> FenceWrapper<&'c C>

Create a new Fence and return a Fence wrapper and a cookie.

This is a thin wrapper around create_fence that allocates an id for the Fence. This function returns the resulting FenceWrapper that owns the created Fence and frees it in Drop. This also returns a VoidCookie that comes from the call to create_fence.

Errors can come from the call to X11Connection::generate_id or create_fence.

Source§

impl<C: X11Connection> FenceWrapper<C>

Source

pub fn create_fence( conn: C, drawable: Drawable, initially_triggered: bool, ) -> Result<Self, ReplyOrIdError>

Create a new Fence and return a Fence wrapper

This is a thin wrapper around create_fence that allocates an id for the Fence. This function returns the resulting FenceWrapper that owns the created Fence and frees it in Drop.

Errors can come from the call to X11Connection::generate_id or create_fence.

Source§

impl<'c, C: X11Connection> FenceWrapper<&'c C>

Create a new Fence and return a Fence wrapper and a cookie.

This is a thin wrapper around super::dri3::fence_from_fd that allocates an id for the Fence. This function returns the resulting FenceWrapper that owns the created Fence and frees it in Drop. This also returns a VoidCookie that comes from the call to super::dri3::fence_from_fd.

Errors can come from the call to X11Connection::generate_id or super::dri3::fence_from_fd.

Source§

impl<C: X11Connection> FenceWrapper<C>

Source

pub fn dri3_fence_from_fd<A>( conn: C, drawable: Drawable, initially_triggered: bool, fence_fd: A, ) -> Result<Self, ReplyOrIdError>
where A: Into<RawFdContainer>,

Create a new Fence and return a Fence wrapper

This is a thin wrapper around super::dri3::fence_from_fd that allocates an id for the Fence. This function returns the resulting FenceWrapper that owns the created Fence and frees it in Drop.

Errors can come from the call to X11Connection::generate_id or super::dri3::fence_from_fd.

Trait Implementations§

Source§

impl<C: Debug + RequestConnection> Debug for FenceWrapper<C>

Source§

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

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

impl<C: RequestConnection> Drop for FenceWrapper<C>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<C: RequestConnection> From<&FenceWrapper<C>> for Fence

Source§

fn from(from: &FenceWrapper<C>) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

§

impl<C> Freeze for FenceWrapper<C>
where C: Freeze,

§

impl<C> RefUnwindSafe for FenceWrapper<C>
where C: RefUnwindSafe,

§

impl<C> Send for FenceWrapper<C>
where C: Send,

§

impl<C> Sync for FenceWrapper<C>
where C: Sync,

§

impl<C> Unpin for FenceWrapper<C>
where C: Unpin,

§

impl<C> UnwindSafe for FenceWrapper<C>
where C: UnwindSafe,

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
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>,

Source§

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>,

Source§

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.