Struct LocalCellData

Source
pub struct LocalCellData<T> { /* private fields */ }
Expand description

User-data wrapper analogous to a Arc<RefCell<T>>, that is restricted to the thread where it was originally created. The destructor of T is not guaranteed to be run if this is actually shared across multiple threads.

This works by checking ThreadId before touching the underlying reference. If the id doesn’t match the original thread, map and map_mut will return an error.

Since it isn’t possible to control where the last reference is dropped, the destructor isn’t run if the last reference is dropped on a different thread than the one where the wrapper was originally created. To ensure that values are cleaned up properly, keep the game single-threaded, or use a real thread-safe wrapper such as MutexData instead.

Trait Implementations§

Source§

impl<T> Clone for LocalCellData<T>

Source§

fn clone(&self) -> Self

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<T: Debug> Debug for LocalCellData<T>

Source§

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

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

impl<T> Map for LocalCellData<T>
where T: NativeClass,

Source§

type Err = LocalCellError

Source§

fn map<F, U>(&self, op: F) -> Result<U, Self::Err>
where F: FnOnce(&Self::Target) -> U,

Maps a &T to U. Called for methods that take &self. Read more
Source§

impl<T> MapMut for LocalCellData<T>
where T: NativeClass,

Source§

type Err = LocalCellError

Source§

fn map_mut<F, U>(&self, op: F) -> Result<U, Self::Err>
where F: FnOnce(&mut Self::Target) -> U,

Maps a &mut T to U. Called for methods that take &mut self. Read more
Source§

impl<T> UserData for LocalCellData<T>
where T: NativeClass,

Source§

type Target = T

Source§

fn new(val: Self::Target) -> Self

Creates a new owned wrapper from a NativeClass instance. Read more
Source§

fn into_user_data(self) -> *const c_void

Takes a native instance and returns an opaque pointer that can be used to recover it. Read more
Source§

unsafe fn consume_user_data_unchecked(ptr: *const c_void) -> Self

Takes an opaque pointer produced by into_user_data and “consumes” it to produce the original instance, keeping the reference count. Read more
Source§

unsafe fn clone_from_user_data_unchecked(ptr: *const c_void) -> Self

Takes an opaque pointer produced by into_user_data and “clones” it to produce the original instance, increasing the reference count. Read more

Auto Trait Implementations§

§

impl<T> Freeze for LocalCellData<T>

§

impl<T> !RefUnwindSafe for LocalCellData<T>

§

impl<T> Send for LocalCellData<T>

§

impl<T> Sync for LocalCellData<T>

§

impl<T> Unpin for LocalCellData<T>

§

impl<T> !UnwindSafe for LocalCellData<T>

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

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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,

Source§

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