Struct gio::IOExtensionPoint

source ·
pub struct IOExtensionPoint(/* private fields */);
Expand description

An extension point provides a mechanism to extend the functionality of a library or application. Each extension point is identified by a name, and it may optionally require that any implementation must be of a certain type. IOExtensionPoint is an opaque data structure and can only be accessed using the following functions.

Implementations§

source§

impl IOExtensionPoint

source

pub fn builder(name: impl Into<GString>) -> IOExtensionPointBuilder

Create a new builder for an extension point.

source

pub fn lookup(name: impl IntoGStr) -> Option<Self>

Looks up an existing extension point.

name

the name of the extension point

Returns

the IOExtensionPoint, or None if there is no registered extension point with the given name.

source

pub fn extensions(&self) -> Vec<IOExtension>

Gets a list of all extensions that implement this extension point. The list is sorted by priority, beginning with the highest priority.

Returns

a GList of GIOExtensions. The list is owned by GIO and should not be modified.

source

pub fn extension_by_name(&self, name: impl IntoGStr) -> Option<IOExtension>

Finds a IOExtension for an extension point by name.

name

the name of the extension to get

Returns

the IOExtension for self that has the given name, or None if there is no extension with that name

source

pub fn required_type(&self) -> Type

Gets the required type for self.

Returns

the GType that all implementations must have, or G_TYPE_INVALID if the extension point has no required type

source

pub fn implement( extension_point_name: impl IntoGStr, type_: Type, extension_name: impl IntoGStr, priority: i32 ) -> Option<IOExtension>

Registers type_ as extension for the extension point with name extension_point_name.

If type_ has already been registered as an extension for this extension point, the existing IOExtension object is returned.

extension_point_name

the name of the extension point

type_

the GType to register as extension

extension_name

the name for the extension

priority

the priority for the extension

Returns

a IOExtension object for GType

Trait Implementations§

source§

impl Clone for IOExtensionPoint

source§

fn clone(&self) -> IOExtensionPoint

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for IOExtensionPoint

source§

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

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

impl Display for IOExtensionPoint

source§

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

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

impl FromGlibPtrNone<*mut *mut _GIOExtensionPoint> for IOExtensionPoint

source§

impl PartialEq for IOExtensionPoint

source§

fn eq(&self, other: &IOExtensionPoint) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<'a> ToGlibPtr<'a, *mut *mut _GIOExtensionPoint> for &'a IOExtensionPoint

§

type Storage = PhantomData<&'a IOExtensionPoint>

source§

fn to_glib_none( &self ) -> Stash<'a, *mut GIOExtensionPoint, &'a IOExtensionPoint>

Transfer: none. Read more
source§

fn to_glib_container(&'a self) -> Stash<'a, P, Self>

Transfer: container. Read more
source§

fn to_glib_full(&self) -> P

Transfer: full. Read more
source§

impl Copy for IOExtensionPoint

source§

impl Eq for IOExtensionPoint

source§

impl StructuralEq for IOExtensionPoint

source§

impl StructuralPartialEq for IOExtensionPoint

Auto Trait Implementations§

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> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
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.