[−][src]Struct abi_stable::sabi_types::StaticRef
A wrapper type for vtable static references,
and other constants that have non-'static
generic parameters
but are safe to reference for the lifetime of T
.
Purpose
This type is necessary because Rust doesn't understand that vtables live for 'static
,
even though they have non-'static
type parameters.
Example
This defines a non-extensible vtable,using a StaticRef as the pointer to the vtable.
use abi_stable::{ marker_type::ErasedObject, prefix_type::{PrefixTypeTrait,WithMetadata}, sabi_types::StaticRef, utils::transmute_mut_reference, StableAbi, sabi_extern_fn, staticref, }; use std::{ marker::PhantomData, ops::Deref, }; fn main(){ let boxed = BoxLike::new("foo".to_string()); assert_eq!(boxed.as_str(), "foo"); } /// An ffi-safe `Box<T>` #[repr(C)] #[derive(StableAbi)] pub struct BoxLike<T> { data: *mut T, vtable: StaticRef<VTable<T>>, _marker: PhantomData<T>, } impl<T> BoxLike<T> { pub fn new(value: T) -> Self { Self{ data: Box::into_raw(Box::new(value)), vtable: VTable::<T>::VTABLE, _marker: PhantomData, } } } impl<T> Drop for BoxLike<T> { fn drop(&mut self){ unsafe{ (self.vtable.drop_)(self.data); } } } impl<T> Deref for BoxLike<T> { type Target = T; fn deref(&self) -> &T { unsafe{ &*self.data } } } #[repr(C)] #[derive(StableAbi)] pub struct VTable<T>{ drop_:unsafe extern "C" fn(*mut T), } impl<T> VTable<T> { // The `staticref` macro declares a `StaticRef<VTable<T>>` constant. staticref!(const VTABLE: Self = Self{ drop_: drop_box::<T>, }); } #[sabi_extern_fn] unsafe fn drop_box<T>(object: *mut T){ drop(Box::from_raw(object)); }
Implementations
impl<T, P> StaticRef<WithMetadata_<T, P>>
[src]
pub const fn as_prefix(self) -> PrefixRef<P>
[src]
Constructs a PrefixRef<P>
from self.
This is most useful when you have a generic type that isn't 'static
for type system reasons, but lives for the entire program.
Example
use abi_stable::{ for_examples::{Module, Module_Ref}, prefix_type::{PrefixRef, PrefixTypeTrait, WithMetadata}, std_types::{RNone, RStr}, staticref, }; // The `staticref` invocation here declares a `StaticRef<WithMetadata<Module>>` constant. const WITH_META: &WithMetadata<Module> = &WithMetadata::new( PrefixTypeTrait::METADATA, Module { first: RNone, second: RStr::from_str("hello"), third: 100, }, ); const MOD: Module_Ref = Module_Ref(WITH_META.static_as_prefix()); assert_eq!(MOD.first(), RNone); assert_eq!(MOD.second().as_str(), "hello");
impl<T> StaticRef<T>
[src]
pub const unsafe fn from_raw(ref_: *const T) -> Self
[src]
Constructs this StaticRef from a raw pointer.
Safety
You must ensure that the raw pointer is valid for the entire program's lifetime.
Example
use abi_stable::sabi_types::StaticRef; struct GetPtr<T>(T); impl<T> GetPtr<T>{ const PTR:*const Option<T>=&None; const STATIC:StaticRef<Option<T>>=unsafe{ StaticRef::from_raw(Self::PTR) }; }
pub const fn new(ref_: &'static T) -> Self
[src]
Constructs this StaticRef from a static reference
This implicitly requires that T:'static
.
Example
use abi_stable::sabi_types::StaticRef; struct GetPtr<T>(T); impl<T> GetPtr<T> where T:'static { const REF:&'static Option<T>=&None; const STATIC:StaticRef<Option<T>>= StaticRef::new(Self::REF); }
pub fn leak_value(val: T) -> Self
[src]
Creates a StaticRef by heap allocating and leaking val
.
pub fn get<'a>(self) -> &'a T
[src]
Gets access to the reference.
This returns &'a T
instead of &'static T
to support vtables of non-'static
types.
Example
use abi_stable::sabi_types::StaticRef; struct GetPtr<T>(T); impl<T> GetPtr<T>{ const PTR:*const Option<T>=&None; const STATIC:StaticRef<Option<T>>=unsafe{ StaticRef::from_raw(Self::PTR) }; } let reference:&'static Option<String>= GetPtr::<String>::STATIC.get();
pub const fn get_raw(self) -> *const T
[src]
Gets access to the referenced value,as a raw pointer.
Example
use abi_stable::sabi_types::StaticRef; use std::convert::Infallible; struct GetPtr<T>(T); impl<T> GetPtr<T>{ const PTR:*const Option<T>=&None; const STATIC:StaticRef<Option<T>>=unsafe{ StaticRef::from_raw(Self::PTR) }; } let reference:*const Option<Infallible>= GetPtr::<Infallible>::STATIC.get_raw();
pub const unsafe fn transmute_ref<U>(self) -> StaticRef<U>
[src]
Transmutes this StaticRef<T>
to a StaticRef<U>
.
Safety
StaticRef has the same rules that references have regarding transmuting from one type to another:
Example
use abi_stable::sabi_types::StaticRef; struct GetPtr<T>(T); impl<T> GetPtr<T>{ const PTR:*const Option<T>=&None; const STATIC:StaticRef<Option<T>>=unsafe{ StaticRef::from_raw(Self::PTR) }; } let reference:StaticRef<Option<[();0xFFF_FFFF]>>=unsafe{ GetPtr::<()>::STATIC .transmute_ref::<Option<[();0xFFF_FFFF]>>() };
Trait Implementations
impl<T, U> CanTransmuteElement<U> for StaticRef<T>
[src]
type TransmutedPtr = StaticRef<U>
The type of the pointer after it's element type has been changed.
impl<T> Clone for StaticRef<T>
[src]
pub fn clone(&self) -> Self
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl<T> Copy for StaticRef<T>
[src]
impl<T> Debug for StaticRef<T> where
T: Debug,
[src]
T: Debug,
impl<T> Deref for StaticRef<T>
[src]
impl<T> Display for StaticRef<T> where
T: Display,
[src]
T: Display,
impl<T> Eq for StaticRef<T> where
T: Eq,
[src]
T: Eq,
impl<T> GetPointerKind for StaticRef<T>
[src]
impl<T> GetStaticEquivalent_ for StaticRef<T> where
T: __StableAbi,
[src]
T: __StableAbi,
type StaticEquivalent = _static_StaticRef<__GetStaticEquivalent<T>>
impl<T> Hash for StaticRef<T> where
T: Hash,
[src]
T: Hash,
pub fn hash<H>(&self, state: &mut H) where
H: Hasher,
[src]
H: Hasher,
pub fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher,
1.3.0[src]
H: Hasher,
impl<T> Ord for StaticRef<T> where
T: Ord,
[src]
T: Ord,
pub fn cmp(&self, other: &Self) -> Ordering
[src]
#[must_use]pub fn max(self, other: Self) -> Self
1.21.0[src]
#[must_use]pub fn min(self, other: Self) -> Self
1.21.0[src]
#[must_use]pub fn clamp(self, min: Self, max: Self) -> Self
1.50.0[src]
impl<T> PartialEq<StaticRef<T>> for StaticRef<T> where
T: PartialEq,
[src]
T: PartialEq,
pub fn eq(&self, other: &Self) -> bool
[src]
#[must_use]pub fn ne(&self, other: &Rhs) -> bool
1.0.0[src]
impl<T> PartialOrd<StaticRef<T>> for StaticRef<T> where
T: PartialOrd,
[src]
T: PartialOrd,
pub fn partial_cmp(&self, other: &Self) -> Option<Ordering>
[src]
#[must_use]pub fn lt(&self, other: &Rhs) -> bool
1.0.0[src]
#[must_use]pub fn le(&self, other: &Rhs) -> bool
1.0.0[src]
#[must_use]pub fn gt(&self, other: &Rhs) -> bool
1.0.0[src]
#[must_use]pub fn ge(&self, other: &Rhs) -> bool
1.0.0[src]
impl<'a, T: 'a> Send for StaticRef<T> where
&'a T: Send,
[src]
&'a T: Send,
impl<T> StableAbi for StaticRef<T> where
T: __StableAbi,
[src]
T: __StableAbi,
type IsNonZeroType = <NonNull<T> as __StableAbi>::IsNonZeroType
Whether this type has a single invalid bit-pattern. Read more
pub const LAYOUT: &'static TypeLayout
[src]
pub const ABI_CONSTS: AbiConsts
[src]
impl<'a, T: 'a> Sync for StaticRef<T> where
&'a T: Sync,
[src]
&'a T: Sync,
Auto Trait Implementations
impl<T> RefUnwindSafe for StaticRef<T> where
T: RefUnwindSafe,
[src]
T: RefUnwindSafe,
impl<T> Unpin for StaticRef<T>
[src]
impl<T> UnwindSafe for StaticRef<T> where
T: RefUnwindSafe,
[src]
T: RefUnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<'a, T> BorrowOwned<'a> for T where
T: 'a + Clone,
[src]
T: 'a + Clone,
type ROwned = T
The owned type, stored in RCow::Owned
type RBorrowed = &'a T
The borrowed type, stored in RCow::Borrowed
pub fn r_borrow(
&'a <T as BorrowOwned<'a>>::ROwned
) -> <T as BorrowOwned<'a>>::RBorrowed
[src]
&'a <T as BorrowOwned<'a>>::ROwned
) -> <T as BorrowOwned<'a>>::RBorrowed
pub fn r_to_owned(
<T as BorrowOwned<'a>>::RBorrowed
) -> <T as BorrowOwned<'a>>::ROwned
[src]
<T as BorrowOwned<'a>>::RBorrowed
) -> <T as BorrowOwned<'a>>::ROwned
pub fn deref_borrowed(&<T as BorrowOwned<'a>>::RBorrowed) -> &T
[src]
pub fn deref_owned(&<T as BorrowOwned<'a>>::ROwned) -> &T
[src]
pub fn from_cow_borrow(&'a T) -> <T as BorrowOwned<'a>>::RBorrowed
[src]
pub fn from_cow_owned(<T as ToOwned>::Owned) -> <T as BorrowOwned<'a>>::ROwned
[src]
pub fn into_cow_borrow(<T as BorrowOwned<'a>>::RBorrowed) -> &'a T
[src]
pub fn into_cow_owned(<T as BorrowOwned<'a>>::ROwned) -> <T as ToOwned>::Owned
[src]
impl<T> From<T> for T
[src]
impl<T> GetWithMetadata for T
[src]
type ForSelf = WithMetadata_<T, T>
This is always WithMetadata_<Self, Self>
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> SelfOps for T where
T: ?Sized,
[src]
T: ?Sized,
pub const T: PhantomData<fn() -> Self>
[src]
pub const T_D: PhantomData<Self>
[src]
pub fn assert_ty(self, _other: PhantomData<fn() -> Self>) -> Self
[src]
pub fn assert_ty_ref(&self, _other: PhantomData<fn() -> Self>) -> &Self
[src]
pub fn assert_ty_mut(&mut self, _other: PhantomData<fn() -> Self>) -> &mut Self
[src]
pub fn ty_(&self) -> PhantomData<fn() -> Self>
[src]
pub fn ty_d(&self) -> PhantomData<Self>
[src]
pub fn ty_inv(&self) -> PhantomData<fn(Self) -> Self>
[src]
pub fn ty_inv_ref(&self) -> PhantomData<Cell<&Self>>
[src]
pub fn eq_id(&self, other: &Self) -> bool
[src]
pub fn piped<F, U>(self, f: F) -> U where
F: FnOnce(Self) -> U,
[src]
F: FnOnce(Self) -> U,
pub fn piped_ref<'a, F, U>(&'a self, f: F) -> U where
F: FnOnce(&'a Self) -> U,
[src]
F: FnOnce(&'a Self) -> U,
pub fn piped_mut<'a, F, U>(&'a mut self, f: F) -> U where
F: FnOnce(&'a mut Self) -> U,
[src]
F: FnOnce(&'a mut Self) -> U,
pub fn mutated<F>(self, f: F) -> Self where
F: FnOnce(&mut Self),
[src]
F: FnOnce(&mut Self),
pub fn observe<F>(self, f: F) -> Self where
F: FnOnce(&Self),
[src]
F: FnOnce(&Self),
pub fn into_<T>(self, PhantomData<fn() -> T>) -> T where
Self: Into<T>,
[src]
Self: Into<T>,
pub fn as_ref_<T>(&self) -> &T where
Self: AsRef<T>,
T: ?Sized,
[src]
Self: AsRef<T>,
T: ?Sized,
pub fn as_mut_<T>(&mut self) -> &mut T where
Self: AsMut<T>,
T: ?Sized,
[src]
Self: AsMut<T>,
T: ?Sized,
pub fn drop_(self)
[src]
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn clone_into(&self, target: &mut T)
[src]
impl<T> ToString for T where
T: Display + ?Sized,
[src]
T: Display + ?Sized,
impl<This> TransmuteElement for This where
This: ?Sized,
[src]
This: ?Sized,
pub unsafe fn transmute_element<T>(self) -> Self::TransmutedPtr where
Self: CanTransmuteElement<T>,
Self::Target: Sized,
[src]
Self: CanTransmuteElement<T>,
Self::Target: Sized,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The error type returned when the conversion fails.
pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> TypeIdentity for T where
T: ?Sized,
[src]
T: ?Sized,
type Type = T
The same type as Self. Read more
pub fn into_type_val(self) -> Self::Type where
Self::Type: Sized,
[src]
Self::Type: Sized,
pub fn into_type_ref(&self) -> &Self::Type
[src]
pub fn into_type_mut(&mut self) -> &mut Self::Type
[src]
pub fn into_type_box(self: Box<Self, Global>) -> Box<Self::Type, Global>
[src]
pub fn into_type_arc(this: Arc<Self>) -> Arc<Self::Type>
[src]
pub fn into_type_rc(this: Rc<Self>) -> Rc<Self::Type>
[src]
pub fn from_type_val(this: Self::Type) -> Self where
Self::Type: Sized,
[src]
Self::Type: Sized,
pub fn from_type_ref(this: &Self::Type) -> &Self
[src]
pub fn from_type_mut(this: &mut Self::Type) -> &mut Self
[src]
pub fn from_type_box(this: Box<Self::Type, Global>) -> Box<Self, Global>
[src]
pub fn from_type_arc(this: Arc<Self::Type>) -> Arc<Self>
[src]
pub fn from_type_rc(this: Rc<Self::Type>) -> Rc<Self>
[src]
impl<This> ValidTag_Bounds for This where
This: Debug + Clone + PartialEq<This>,
[src]
This: Debug + Clone + PartialEq<This>,