pub struct UserDataMap { /* private fields */ }
Expand description
A storage able to store several values of UserData
of different types. It behaves similarly to a TypeMap
.
Implementations§
Source§impl UserDataMap
impl UserDataMap
Sourcepub fn new() -> UserDataMap
pub fn new() -> UserDataMap
Create a new map
Sourcepub fn get<T: 'static>(&self) -> Option<&T>
pub fn get<T: 'static>(&self) -> Option<&T>
Attempt to access the wrapped user data of a given type
Will return None
if no value of type T
is stored in this UserDataMap
and accessible from this thread
Sourcepub fn insert_if_missing<T: 'static, F: FnOnce() -> T>(&self, init: F) -> bool
pub fn insert_if_missing<T: 'static, F: FnOnce() -> T>(&self, init: F) -> bool
Insert a value in the map if it is not already there
This is the non-threadsafe variant, the type you insert don’t have to be threadsafe, but they will not be visible from other threads (even if they are actually threadsafe).
If the value does not already exists, the closure is called to create it and
this function returns true
. If the value already exists, the closure is not
called, and this function returns false
.
Sourcepub fn insert_if_missing_threadsafe<T: Send + Sync + 'static, F: FnOnce() -> T>(
&self,
init: F,
) -> bool
pub fn insert_if_missing_threadsafe<T: Send + Sync + 'static, F: FnOnce() -> T>( &self, init: F, ) -> bool
Insert a value in the map if it is not already there
This is the threadsafe variant, the type you insert must be threadsafe and will be visible from all threads.
If the value does not already exists, the closure is called to create it and
this function returns true
. If the value already exists, the closure is not
called, and this function returns false
.