x11rb::protocol::xfixes

Struct RegionWrapper

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

A RAII-like wrapper around a Region.

Instances of this struct represent a Region 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> RegionWrapper<C>

Source

pub fn for_region(conn: C, id: Region) -> Self

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

Source

pub fn region(&self) -> Region

Get the XID of the wrapped resource

Source

pub fn into_region(self) -> Region

Assume ownership of the XID of the wrapped resource

This function destroys this wrapper without freeing the underlying resource.

Source§

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

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

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

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

Source§

impl<C: X11Connection> RegionWrapper<C>

Source

pub fn create_region( conn: C, rectangles: &[Rectangle], ) -> Result<Self, ReplyOrIdError>

Create a new Region and return a Region wrapper

This is a thin wrapper around create_region that allocates an id for the Region. This function returns the resulting RegionWrapper that owns the created Region and frees it in Drop.

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

Source§

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

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

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

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

Source§

impl<C: X11Connection> RegionWrapper<C>

Source

pub fn create_region_from_bitmap( conn: C, bitmap: Pixmap, ) -> Result<Self, ReplyOrIdError>

Create a new Region and return a Region wrapper

This is a thin wrapper around create_region_from_bitmap that allocates an id for the Region. This function returns the resulting RegionWrapper that owns the created Region and frees it in Drop.

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

Source§

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

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

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

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

Source§

impl<C: X11Connection> RegionWrapper<C>

Source

pub fn create_region_from_window( conn: C, window: Window, kind: SK, ) -> Result<Self, ReplyOrIdError>

Create a new Region and return a Region wrapper

This is a thin wrapper around create_region_from_window that allocates an id for the Region. This function returns the resulting RegionWrapper that owns the created Region and frees it in Drop.

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

Source§

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

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

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

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

Source§

impl<C: X11Connection> RegionWrapper<C>

Source

pub fn create_region_from_gc( conn: C, gc: Gcontext, ) -> Result<Self, ReplyOrIdError>

Create a new Region and return a Region wrapper

This is a thin wrapper around create_region_from_gc that allocates an id for the Region. This function returns the resulting RegionWrapper that owns the created Region and frees it in Drop.

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

Source§

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

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

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

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

Source§

impl<C: X11Connection> RegionWrapper<C>

Source

pub fn create_region_from_picture( conn: C, picture: Picture, ) -> Result<Self, ReplyOrIdError>

Create a new Region and return a Region wrapper

This is a thin wrapper around create_region_from_picture that allocates an id for the Region. This function returns the resulting RegionWrapper that owns the created Region and frees it in Drop.

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

Source§

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

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

This is a thin wrapper around super::composite::create_region_from_border_clip that allocates an id for the Region. This function returns the resulting RegionWrapper that owns the created Region and frees it in Drop. This also returns a VoidCookie that comes from the call to super::composite::create_region_from_border_clip.

Errors can come from the call to X11Connection::generate_id or super::composite::create_region_from_border_clip.

Source§

impl<C: X11Connection> RegionWrapper<C>

Source

pub fn composite_create_region_from_border_clip( conn: C, window: Window, ) -> Result<Self, ReplyOrIdError>

Create a new Region and return a Region wrapper

This is a thin wrapper around super::composite::create_region_from_border_clip that allocates an id for the Region. This function returns the resulting RegionWrapper that owns the created Region and frees it in Drop.

Errors can come from the call to X11Connection::generate_id or super::composite::create_region_from_border_clip.

Trait Implementations§

Source§

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

Source§

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

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

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

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<C: RequestConnection> From<&RegionWrapper<C>> for Region

Source§

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

Converts to this type from the input type.

Auto Trait Implementations§

§

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

§

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

§

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

§

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

§

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

§

impl<C> UnwindSafe for RegionWrapper<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.