pub struct RefCountedSingleton<T>(/* private fields */);
Expand description

A reference-counted singleton whose protected data can be recreated as needed.

The protected data is created when RefCountedSingleton::get_or_init is called. That function returns an RCSRef reference to the singleton.

RCSRef instances can be cloned as needed. The last RCSRef reference drops the data. Calling RefCountedSingleton::get_or_init again recreates the data.

Implementations§

source§

impl<T> RefCountedSingleton<T>

source

pub fn get_or_init<E: Error>( &self, creator: impl FnOnce() -> Result<T, E> ) -> Result<RCSRef<'_, T>, Option<E>>

Return a counted reference to the protected data if such data exists, otherwise creates a new instance of the data by calling creator().

If the lock is poisoned, then this returns Err(None). If creator() returns an error err, then this returns Err(Some(err)).

source

pub fn get(&self) -> Option<RCSRef<'_, T>>

Return a counted reference to the protected data if such data exists.

If such data is not instantiated, or the lock is poisoned, then this returns None.

Trait Implementations§

source§

impl<T: Debug> Debug for RefCountedSingleton<T>

source§

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

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

impl<T> Default for RefCountedSingleton<T>

source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl<T> !Freeze for RefCountedSingleton<T>

§

impl<T> RefUnwindSafe for RefCountedSingleton<T>

§

impl<T> Send for RefCountedSingleton<T>
where T: Sync + Send,

§

impl<T> Sync for RefCountedSingleton<T>
where T: Sync + Send,

§

impl<T> Unpin for RefCountedSingleton<T>

§

impl<T> UnwindSafe for RefCountedSingleton<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> 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>,

§

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.