Struct otter_api_tests::imports::slotmap::SecondaryMap [−][src]
pub struct SecondaryMap<K, V> where
K: Key, { /* fields omitted */ }
Secondary map, associate data with previously stored elements in a slot map.
A SecondaryMap
allows you to efficiently store additional information
for each element in a slot map. You can have multiple secondary maps per
slot map, but not multiple slot maps per secondary map. It is safe but
unspecified behavior if you use keys from multiple different slot maps in
the same SecondaryMap
.
A SecondaryMap
does not leak memory even if you never remove elements.
In return, when you remove a key from the primary slot map, after any insert
the space associated with the removed element may be reclaimed. Don’t expect
the values associated with a removed key to stick around after an insertion
has happened!
Finally a note on memory complexity, the SecondaryMap
can use memory for
each slot in the primary slot map, and has to iterate over every slot during
iteration, regardless of whether you have inserted an associative value at
that key or not. If you have some property that you only expect to set for a
minority of keys, use a SparseSecondaryMap
,
which is backed by a HashMap
.
Example usage:
let mut players = SlotMap::new(); let mut health = SecondaryMap::new(); let mut ammo = SecondaryMap::new(); let alice = players.insert("alice"); let bob = players.insert("bob"); for p in players.keys() { health.insert(p, 100); ammo.insert(p, 30); } // Alice attacks Bob with all her ammo! health[bob] -= ammo[alice] * 3; ammo[alice] = 0;
Implementations
impl<K, V> SecondaryMap<K, V> where
K: Key,
[src]
K: Key,
pub fn new() -> SecondaryMap<K, V>
[src]
Constructs a new, empty SecondaryMap
.
Examples
let mut sec: SecondaryMap<DefaultKey, i32> = SecondaryMap::new();
pub fn with_capacity(capacity: usize) -> SecondaryMap<K, V>
[src]
Creates an empty SecondaryMap
with the given capacity of slots.
The secondary map will not reallocate until it holds at least capacity
slots. Even inserting a single key-value pair might require as many
slots as the slot map the key comes from, so it’s recommended to match
the capacity of a secondary map to its corresponding slot map.
Examples
let mut sm: SlotMap<_, i32> = SlotMap::with_capacity(10); let mut sec: SecondaryMap<DefaultKey, i32> = SecondaryMap::with_capacity(sm.capacity());
pub fn len(&self) -> usize
[src]
Returns the number of elements in the secondary map.
Examples
let mut sm = SlotMap::new(); let k = sm.insert(4); let mut squared = SecondaryMap::new(); assert_eq!(squared.len(), 0); squared.insert(k, 16); assert_eq!(squared.len(), 1);
pub fn is_empty(&self) -> bool
[src]
Returns if the secondary map is empty.
Examples
let mut sec: SecondaryMap<DefaultKey, i32> = SecondaryMap::new(); assert!(sec.is_empty());
pub fn capacity(&self) -> usize
[src]
Returns the number of elements the SecondaryMap
can hold without
reallocating.
Examples
let mut sec: SecondaryMap<DefaultKey, i32> = SecondaryMap::with_capacity(10); assert!(sec.capacity() >= 10);
pub fn set_capacity(&mut self, new_capacity: usize)
[src]
Sets the capacity of the SecondaryMap
to new_capacity
, if it is
bigger than the current capacity.
It is recommended to set the capacity of a SecondaryMap
to the
capacity of its corresponding slot map before inserting many new
elements to prevent frequent reallocations. The collection may reserve
more space than requested.
Panics
Panics if the new allocation size overflows usize
.
Examples
let mut sec: SecondaryMap<DefaultKey, i32> = SecondaryMap::with_capacity(10); assert!(sec.capacity() >= 10); sec.set_capacity(1000); assert!(sec.capacity() >= 1000);
pub fn contains_key(&self, key: K) -> bool
[src]
Returns true
if the secondary map contains key
.
Examples
let mut sm = SlotMap::new(); let k = sm.insert(4); let mut squared = SecondaryMap::new(); assert!(!squared.contains_key(k)); squared.insert(k, 16); assert!(squared.contains_key(k));
pub fn insert(&mut self, key: K, value: V) -> Option<V>
[src]
Inserts a value into the secondary map at the given key
. Can silently
fail and return None
if key
was removed from the originating slot
map.
Returns None
if this key was not present in the map, the old value
otherwise.
Examples
let mut sm = SlotMap::new(); let k = sm.insert(4); let mut squared = SecondaryMap::new(); assert_eq!(squared.insert(k, 0), None); assert_eq!(squared.insert(k, 4), Some(0)); // You don't have to use insert if the key is already in the secondary map. squared[k] *= squared[k]; assert_eq!(squared[k], 16);
pub fn remove(&mut self, key: K) -> Option<V>
[src]
Removes a key from the secondary map, returning the value at the key if
the key was not previously removed. If key
was removed from the
originating slot map, its corresponding entry in the secondary map may
or may not already be removed.
Examples
let mut sm = SlotMap::new(); let mut squared = SecondaryMap::new(); let k = sm.insert(4); squared.insert(k, 16); squared.remove(k); assert!(!squared.contains_key(k)); // It's not necessary to remove keys deleted from the primary slot map, they // get deleted automatically when their slots are reused on a subsequent insert. squared.insert(k, 16); sm.remove(k); // Remove k from the slot map, making an empty slot. let new_k = sm.insert(2); // Since sm only has one empty slot, this reuses it. assert!(!squared.contains_key(new_k)); // Space reuse does not mean equal keys. assert!(squared.contains_key(k)); // Slot has not been reused in squared yet. squared.insert(new_k, 4); assert!(!squared.contains_key(k)); // Old key is no longer available.
pub fn retain<F>(&mut self, f: F) where
F: FnMut(K, &mut V) -> bool,
[src]
F: FnMut(K, &mut V) -> bool,
Retains only the elements specified by the predicate.
In other words, remove all key-value pairs (k, v)
such that
f(k, &mut v)
returns false. This method invalidates any removed keys.
This function must iterate over all slots, empty or not. In the face of many deleted elements it can be inefficient.
Examples
let mut sm = SlotMap::new(); let mut sec = SecondaryMap::new(); let k1 = sm.insert(0); sec.insert(k1, 10); let k2 = sm.insert(1); sec.insert(k2, 11); let k3 = sm.insert(2); sec.insert(k3, 12); sec.retain(|key, val| key == k1 || *val == 11); assert!(sec.contains_key(k1)); assert!(sec.contains_key(k2)); assert!(!sec.contains_key(k3)); assert_eq!(sec.len(), 2);
pub fn clear(&mut self)
[src]
Clears the secondary map. Keeps the allocated memory for reuse.
This function must iterate over all slots, empty or not. In the face of many deleted elements it can be inefficient.
Examples
let mut sm = SlotMap::new(); let mut sec = SecondaryMap::new(); for i in 0..10 { sec.insert(sm.insert(i), i); } assert_eq!(sec.len(), 10); sec.clear(); assert_eq!(sec.len(), 0);
pub fn drain(&mut self) -> Drain<'_, K, V>ⓘ
[src]
Clears the slot map, returning all key-value pairs in arbitrary order as an iterator. Keeps the allocated memory for reuse.
When the iterator is dropped all elements in the slot map are removed,
even if the iterator was not fully consumed. If the iterator is not
dropped (using e.g. std::mem::forget
), only the elements that were
iterated over are removed.
This function must iterate over all slots, empty or not. In the face of many deleted elements it can be inefficient.
Examples
let mut sm = SlotMap::new(); let k = sm.insert(0); let mut sec = SecondaryMap::new(); sec.insert(k, 1); let v: Vec<_> = sec.drain().collect(); assert_eq!(sec.len(), 0); assert_eq!(v, vec![(k, 1)]);
pub fn get(&self, key: K) -> Option<&V>
[src]
Returns a reference to the value corresponding to the key.
Examples
let mut sm = SlotMap::new(); let key = sm.insert("foo"); let mut sec = SecondaryMap::new(); sec.insert(key, "bar"); assert_eq!(sec.get(key), Some(&"bar")); sec.remove(key); assert_eq!(sec.get(key), None);
pub unsafe fn get_unchecked(&self, key: K) -> &VⓘNotable traits for &'_ mut R
impl<'_, R> Read for &'_ mut R where
R: Read + ?Sized, impl<'_, W> Write for &'_ mut W where
W: Write + ?Sized, impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;impl<'_, F> Future for &'_ mut F where
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;
[src]
Notable traits for &'_ mut R
impl<'_, R> Read for &'_ mut R where
R: Read + ?Sized, impl<'_, W> Write for &'_ mut W where
W: Write + ?Sized, impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;impl<'_, F> Future for &'_ mut F where
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;
Returns a reference to the value corresponding to the key without version or bounds checking.
Safety
This should only be used if contains_key(key)
is true. Otherwise it is
potentially unsafe.
Examples
let mut sm = SlotMap::new(); let key = sm.insert("foo"); let mut sec = SecondaryMap::new(); sec.insert(key, "bar"); assert_eq!(unsafe { sec.get_unchecked(key) }, &"bar"); sec.remove(key); // sec.get_unchecked(key) is now dangerous!
pub fn get_mut(&mut self, key: K) -> Option<&mut V>
[src]
Returns a mutable reference to the value corresponding to the key.
Examples
let mut sm = SlotMap::new(); let key = sm.insert("test"); let mut sec = SecondaryMap::new(); sec.insert(key, 3.5); if let Some(x) = sec.get_mut(key) { *x += 3.0; } assert_eq!(sec[key], 6.5);
pub unsafe fn get_unchecked_mut(&mut self, key: K) -> &mut VⓘNotable traits for &'_ mut R
impl<'_, R> Read for &'_ mut R where
R: Read + ?Sized, impl<'_, W> Write for &'_ mut W where
W: Write + ?Sized, impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;impl<'_, F> Future for &'_ mut F where
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;
[src]
Notable traits for &'_ mut R
impl<'_, R> Read for &'_ mut R where
R: Read + ?Sized, impl<'_, W> Write for &'_ mut W where
W: Write + ?Sized, impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;impl<'_, F> Future for &'_ mut F where
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;
Returns a mutable reference to the value corresponding to the key without version or bounds checking.
Safety
This should only be used if contains_key(key)
is true. Otherwise it is
potentially unsafe.
Examples
let mut sm = SlotMap::new(); let key = sm.insert("foo"); let mut sec = SecondaryMap::new(); sec.insert(key, "bar"); unsafe { *sec.get_unchecked_mut(key) = "baz" }; assert_eq!(sec[key], "baz"); sec.remove(key); // sec.get_unchecked_mut(key) is now dangerous!
pub fn iter(&self) -> Iter<'_, K, V>ⓘ
[src]
An iterator visiting all key-value pairs in arbitrary order. The
iterator element type is (K, &'a V)
.
This function must iterate over all slots, empty or not. In the face of many deleted elements it can be inefficient.
Examples
let mut sm = SlotMap::new(); let mut sec = SecondaryMap::new(); let k0 = sm.insert(0); sec.insert(k0, 10); let k1 = sm.insert(1); sec.insert(k1, 11); let k2 = sm.insert(2); sec.insert(k2, 12); for (k, v) in sm.iter() { println!("key: {:?}, val: {}", k, v); }
pub fn iter_mut(&mut self) -> IterMut<'_, K, V>ⓘ
[src]
An iterator visiting all key-value pairs in arbitrary order, with
mutable references to the values. The iterator element type is
(K, &'a mut V)
.
This function must iterate over all slots, empty or not. In the face of many deleted elements it can be inefficient.
Examples
let mut sm = SlotMap::new(); let mut sec = SecondaryMap::new(); let k0 = sm.insert(1); sec.insert(k0, 10); let k1 = sm.insert(2); sec.insert(k1, 20); let k2 = sm.insert(3); sec.insert(k2, 30); for (k, v) in sec.iter_mut() { if k != k1 { *v *= -1; } } assert_eq!(sec[k0], -10); assert_eq!(sec[k1], 20); assert_eq!(sec[k2], -30);
pub fn keys(&self) -> Keys<'_, K, V>ⓘ
[src]
An iterator visiting all keys in arbitrary order. The iterator element
type is K
.
This function must iterate over all slots, empty or not. In the face of many deleted elements it can be inefficient.
Examples
let mut sm = SlotMap::new(); let mut sec = SecondaryMap::new(); let k0 = sm.insert(1); sec.insert(k0, 10); let k1 = sm.insert(2); sec.insert(k1, 20); let k2 = sm.insert(3); sec.insert(k2, 30); let keys: HashSet<_> = sec.keys().collect(); let check: HashSet<_> = vec![k0, k1, k2].into_iter().collect(); assert_eq!(keys, check);
pub fn values(&self) -> Values<'_, K, V>ⓘ
[src]
An iterator visiting all values in arbitrary order. The iterator element
type is &'a V
.
This function must iterate over all slots, empty or not. In the face of many deleted elements it can be inefficient.
Examples
let mut sm = SlotMap::new(); let mut sec = SecondaryMap::new(); let k0 = sm.insert(1); sec.insert(k0, 10); let k1 = sm.insert(2); sec.insert(k1, 20); let k2 = sm.insert(3); sec.insert(k2, 30); let values: HashSet<_> = sec.values().collect(); let check: HashSet<_> = vec![&10, &20, &30].into_iter().collect(); assert_eq!(values, check);
pub fn values_mut(&mut self) -> ValuesMut<'_, K, V>ⓘ
[src]
An iterator visiting all values mutably in arbitrary order. The iterator
element type is &'a mut V
.
This function must iterate over all slots, empty or not. In the face of many deleted elements it can be inefficient.
Examples
let mut sm = SlotMap::new(); let mut sec = SecondaryMap::new(); sec.insert(sm.insert(1), 10); sec.insert(sm.insert(2), 20); sec.insert(sm.insert(3), 30); sec.values_mut().for_each(|n| { *n *= 3 }); let values: HashSet<_> = sec.into_iter().map(|(_k, v)| v).collect(); let check: HashSet<_> = vec![30, 60, 90].into_iter().collect(); assert_eq!(values, check);
pub fn entry(&mut self, key: K) -> Option<Entry<'_, K, V>>
[src]
Gets the given key’s corresponding Entry
in the map for in-place
manipulation. May return None
if the key was removed from the
originating slot map.
Examples
let mut sm = SlotMap::new(); let mut sec = SecondaryMap::new(); let k = sm.insert(1); let v = sec.entry(k).unwrap().or_insert(10); assert_eq!(*v, 10);
Trait Implementations
impl<I, T> ById for SecondaryMap<I, T> where
I: IdForById + Key,
[src]
I: IdForById + Key,
type Id = I
type Entry = T
type Error = <I as IdForById>::Error
pub fn byid(
&self,
t: <SecondaryMap<I, T> as ById>::Id
) -> Result<&T, <SecondaryMap<I, T> as ById>::Error>
[src]
&self,
t: <SecondaryMap<I, T> as ById>::Id
) -> Result<&T, <SecondaryMap<I, T> as ById>::Error>
pub fn byid_mut(
&mut self,
t: <SecondaryMap<I, T> as ById>::Id
) -> Result<&mut T, <SecondaryMap<I, T> as ById>::Error>
[src]
&mut self,
t: <SecondaryMap<I, T> as ById>::Id
) -> Result<&mut T, <SecondaryMap<I, T> as ById>::Error>
impl<K, V> Clone for SecondaryMap<K, V> where
K: Clone + Key,
V: Clone,
[src]
K: Clone + Key,
V: Clone,
pub fn clone(&self) -> SecondaryMap<K, V>
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl<K, V> Debug for SecondaryMap<K, V> where
K: Debug + Key,
V: Debug,
[src]
K: Debug + Key,
V: Debug,
impl<K, V> Default for SecondaryMap<K, V> where
K: Key,
[src]
K: Key,
pub fn default() -> SecondaryMap<K, V>
[src]
impl<'de, K, V> Deserialize<'de> for SecondaryMap<K, V> where
K: Key,
V: Deserialize<'de>,
[src]
K: Key,
V: Deserialize<'de>,
pub fn deserialize<D>(
deserializer: D
) -> Result<SecondaryMap<K, V>, <D as Deserializer<'de>>::Error> where
D: Deserializer<'de>,
[src]
deserializer: D
) -> Result<SecondaryMap<K, V>, <D as Deserializer<'de>>::Error> where
D: Deserializer<'de>,
impl<K, V> Eq for SecondaryMap<K, V> where
K: Key,
V: Eq,
[src]
K: Key,
V: Eq,
impl<'a, K, V> Extend<(K, &'a V)> for SecondaryMap<K, V> where
K: Key,
V: 'a + Copy,
[src]
K: Key,
V: 'a + Copy,
pub fn extend<I>(&mut self, iter: I) where
I: IntoIterator<Item = (K, &'a V)>,
[src]
I: IntoIterator<Item = (K, &'a V)>,
pub fn extend_one(&mut self, item: A)
[src]
pub fn extend_reserve(&mut self, additional: usize)
[src]
impl<K, V> Extend<(K, V)> for SecondaryMap<K, V> where
K: Key,
[src]
K: Key,
pub fn extend<I>(&mut self, iter: I) where
I: IntoIterator<Item = (K, V)>,
[src]
I: IntoIterator<Item = (K, V)>,
pub fn extend_one(&mut self, item: A)
[src]
pub fn extend_reserve(&mut self, additional: usize)
[src]
impl<K, V> FromIterator<(K, V)> for SecondaryMap<K, V> where
K: Key,
[src]
K: Key,
pub fn from_iter<I>(iter: I) -> SecondaryMap<K, V> where
I: IntoIterator<Item = (K, V)>,
[src]
I: IntoIterator<Item = (K, V)>,
impl<K, V> Index<K> for SecondaryMap<K, V> where
K: Key,
[src]
K: Key,
type Output = V
The returned type after indexing.
pub fn index(&self, key: K) -> &VⓘNotable traits for &'_ mut R
impl<'_, R> Read for &'_ mut R where
R: Read + ?Sized, impl<'_, W> Write for &'_ mut W where
W: Write + ?Sized, impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;impl<'_, F> Future for &'_ mut F where
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;
[src]
Notable traits for &'_ mut R
impl<'_, R> Read for &'_ mut R where
R: Read + ?Sized, impl<'_, W> Write for &'_ mut W where
W: Write + ?Sized, impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;impl<'_, F> Future for &'_ mut F where
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;
impl<K, V> IndexMut<K> for SecondaryMap<K, V> where
K: Key,
[src]
K: Key,
pub fn index_mut(&mut self, key: K) -> &mut VⓘNotable traits for &'_ mut R
impl<'_, R> Read for &'_ mut R where
R: Read + ?Sized, impl<'_, W> Write for &'_ mut W where
W: Write + ?Sized, impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;impl<'_, F> Future for &'_ mut F where
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;
[src]
Notable traits for &'_ mut R
impl<'_, R> Read for &'_ mut R where
R: Read + ?Sized, impl<'_, W> Write for &'_ mut W where
W: Write + ?Sized, impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;impl<'_, F> Future for &'_ mut F where
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;
impl<K, V> IntoIterator for SecondaryMap<K, V> where
K: Key,
[src]
K: Key,
type Item = (K, V)
The type of the elements being iterated over.
type IntoIter = IntoIter<K, V>
Which kind of iterator are we turning this into?
pub fn into_iter(self) -> <SecondaryMap<K, V> as IntoIterator>::IntoIter
[src]
impl<'a, K, V> IntoIterator for &'a mut SecondaryMap<K, V> where
K: Key,
[src]
K: Key,
type Item = (K, &'a mut V)
The type of the elements being iterated over.
type IntoIter = IterMut<'a, K, V>
Which kind of iterator are we turning this into?
pub fn into_iter(self) -> <&'a mut SecondaryMap<K, V> as IntoIterator>::IntoIter
[src]
impl<'a, K, V> IntoIterator for &'a SecondaryMap<K, V> where
K: Key,
[src]
K: Key,
type Item = (K, &'a V)
The type of the elements being iterated over.
type IntoIter = Iter<'a, K, V>
Which kind of iterator are we turning this into?
pub fn into_iter(self) -> <&'a SecondaryMap<K, V> as IntoIterator>::IntoIter
[src]
impl<K, V> PartialEq<SecondaryMap<K, V>> for SecondaryMap<K, V> where
K: Key,
V: PartialEq<V>,
[src]
K: Key,
V: PartialEq<V>,
pub fn eq(&self, other: &SecondaryMap<K, V>) -> bool
[src]
#[must_use]pub fn ne(&self, other: &Rhs) -> bool
1.0.0[src]
impl<K, V> Serialize for SecondaryMap<K, V> where
K: Key,
V: Serialize,
[src]
K: Key,
V: Serialize,
pub fn serialize<S>(
&self,
serializer: S
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error> where
S: Serializer,
[src]
&self,
serializer: S
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error> where
S: Serializer,
Auto Trait Implementations
impl<K, V> RefUnwindSafe for SecondaryMap<K, V> where
V: RefUnwindSafe,
V: RefUnwindSafe,
impl<K, V> Send for SecondaryMap<K, V> where
V: Send,
V: Send,
impl<K, V> Sync for SecondaryMap<K, V> where
V: Sync,
V: Sync,
impl<K, V> Unpin for SecondaryMap<K, V> where
V: Unpin,
V: Unpin,
impl<K, V> UnwindSafe for SecondaryMap<K, V> where
V: UnwindSafe,
V: UnwindSafe,
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,
pub fn borrow(&self) -> &TⓘNotable traits for &'_ mut R
impl<'_, R> Read for &'_ mut R where
R: Read + ?Sized, impl<'_, W> Write for &'_ mut W where
W: Write + ?Sized, impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;impl<'_, F> Future for &'_ mut F where
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;
[src]
Notable traits for &'_ mut R
impl<'_, R> Read for &'_ mut R where
R: Read + ?Sized, impl<'_, W> Write for &'_ mut W where
W: Write + ?Sized, impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;impl<'_, F> Future for &'_ mut F where
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut TⓘNotable traits for &'_ mut R
impl<'_, R> Read for &'_ mut R where
R: Read + ?Sized, impl<'_, W> Write for &'_ mut W where
W: Write + ?Sized, impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;impl<'_, F> Future for &'_ mut F where
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;
[src]
Notable traits for &'_ mut R
impl<'_, R> Read for &'_ mut R where
R: Read + ?Sized, impl<'_, W> Write for &'_ mut W where
W: Write + ?Sized, impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;impl<'_, F> Future for &'_ mut F where
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;
impl<T> DeserializeOwned for T where
T: for<'de> Deserialize<'de>,
[src]
T: for<'de> Deserialize<'de>,
impl<T> Downcast for T where
T: Any,
T: Any,
pub fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>ⓘNotable traits for Box<R, Global>
impl<R> Read for Box<R, Global> where
R: Read + ?Sized, impl<W> Write for Box<W, Global> where
W: Write + ?Sized, impl<F, A> Future for Box<F, A> where
A: Allocator + 'static,
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
A: Allocator,
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;
Notable traits for Box<R, Global>
impl<R> Read for Box<R, Global> where
R: Read + ?Sized, impl<W> Write for Box<W, Global> where
W: Write + ?Sized, impl<F, A> Future for Box<F, A> where
A: Allocator + 'static,
F: Future + Unpin + ?Sized, type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
A: Allocator,
I: Iterator + ?Sized, type Item = <I as Iterator>::Item;
pub fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
pub fn as_any(&self) -> &(dyn Any + 'static)
pub fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
impl<T> DowncastSync for T where
T: Any + Send + Sync,
T: Any + Send + Sync,
impl<A> DynCastExt for A
pub fn dyn_cast<T>(
self
) -> Result<<A as DynCastExtHelper<T>>::Target, <A as DynCastExtHelper<T>>::Source> where
T: ?Sized,
A: DynCastExtHelper<T>,
self
) -> Result<<A as DynCastExtHelper<T>>::Target, <A as DynCastExtHelper<T>>::Source> where
T: ?Sized,
A: DynCastExtHelper<T>,
pub fn dyn_upcast<T>(self) -> <A as DynCastExtAdvHelper<T, T>>::Target where
T: ?Sized,
A: DynCastExtAdvHelper<T, T, Source = <A as DynCastExtAdvHelper<T, T>>::Target>,
T: ?Sized,
A: DynCastExtAdvHelper<T, T, Source = <A as DynCastExtAdvHelper<T, T>>::Target>,
pub fn dyn_cast_adv<F, T>(
self
) -> Result<<A as DynCastExtAdvHelper<F, T>>::Target, <A as DynCastExtAdvHelper<F, T>>::Source> where
T: ?Sized,
A: DynCastExtAdvHelper<F, T>,
F: ?Sized,
self
) -> Result<<A as DynCastExtAdvHelper<F, T>>::Target, <A as DynCastExtAdvHelper<F, T>>::Source> where
T: ?Sized,
A: DynCastExtAdvHelper<F, T>,
F: ?Sized,
pub fn dyn_cast_with_config<C>(
self
) -> Result<<A as DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>>::Target, <A as DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>>::Source> where
C: DynCastConfig,
A: DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>,
self
) -> Result<<A as DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>>::Target, <A as DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>>::Source> where
C: DynCastConfig,
A: DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>,
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> Serialize for T where
T: Serialize + ?Sized,
[src]
T: Serialize + ?Sized,
pub fn erased_serialize(
&self,
serializer: &mut dyn Serializer
) -> Result<Ok, Error>
[src]
&self,
serializer: &mut dyn Serializer
) -> Result<Ok, Error>
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, 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<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,