abi_stable::pointer_trait

Trait GetPointerKind

Source
pub unsafe trait GetPointerKind: Sized {
    type Kind: PointerKindVariant;
    type PtrTarget;

    const KIND: PointerKind = <Self::Kind as PointerKindVariant>::VALUE;
}
Expand description

What kind of pointer this is.

§Safety

Each associated item describes their requirements for the implementor.

Provided Associated Constants§

Source

const KIND: PointerKind = <Self::Kind as PointerKindVariant>::VALUE

The value-level version of the Kind associated type.

§Safety for implementor

This must not be overriden.

Required Associated Types§

Source

type Kind: PointerKindVariant

The kind of the pointer.

§Safety for implementor

This is what each kind requires to be used as this associated type:

  • PK_Reference: Self must be a &T, or a Copy and #[repr(transparent)] wrapper around a raw pointer or reference, with &T semantics. Note that converting into and then back from &Self::PtrTarget might be a lossy operation for such a type and therefore incorrect.

  • PK_MutReference: Self must be a &mut T, or a non-Drop and #[repr(transparent)] wrapper around a primitive pointer, with &mut T semantics.

  • PK_SmartPointer: Any pointer type that’s neither of the two other kinds.

Source

type PtrTarget

What this pointer points to.

This is here so that pointers don’t have to implement Deref.

§Safety for implementor

If the type implements std::ops::Deref this must be the same as <Self as Deref>::Target.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementations on Foreign Types§

Source§

impl<'a, T> GetPointerKind for &'a T

Source§

impl<'a, T> GetPointerKind for &'a mut T

Implementors§