pub struct HashConsed<T>(HashByAddr<Arc<T>>);Expand description
Hash-consed data structure: a reference-counted wrapper that guarantees that two equal value will be stored at the same address. This makes it possible to use the pointer address as a hash value.
Tuple Fields§
§0: HashByAddr<Arc<T>>Implementations§
Source§impl<T> HashConsed<T>
impl<T> HashConsed<T>
Trait Implementations§
Source§impl<T: Clone> Clone for HashConsed<T>
impl<T: Clone> Clone for HashConsed<T>
Source§fn clone(&self) -> HashConsed<T>
fn clone(&self) -> HashConsed<T>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl<T: Debug> Debug for HashConsed<T>
impl<T: Debug> Debug for HashConsed<T>
Source§impl<'de, T> Deserialize<'de> for HashConsed<T>
Manual impl to make sure we re-establish sharing!
impl<'de, T> Deserialize<'de> for HashConsed<T>
Manual impl to make sure we re-establish sharing!
Source§fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl<'s, T, V: Visit<'s, T>> Drive<'s, V> for HashConsed<T>
impl<'s, T, V: Visit<'s, T>> Drive<'s, V> for HashConsed<T>
Source§fn drive_inner(&'s self, v: &mut V) -> ControlFlow<V::Break>
fn drive_inner(&'s self, v: &mut V) -> ControlFlow<V::Break>
Call
v.visit() on the immediate contents of self.Source§impl<'s, T, V> DriveMut<'s, V> for HashConsed<T>
Note: this explores the inner value mutably by cloning and re-hashing afterwards.
impl<'s, T, V> DriveMut<'s, V> for HashConsed<T>
Note: this explores the inner value mutably by cloning and re-hashing afterwards.
Source§fn drive_inner_mut(&'s mut self, v: &mut V) -> ControlFlow<V::Break>
fn drive_inner_mut(&'s mut self, v: &mut V) -> ControlFlow<V::Break>
Call
v.visit() on the immediate contents of self.Source§impl<T: Hash> Hash for HashConsed<T>
impl<T: Hash> Hash for HashConsed<T>
Source§impl<T: PartialEq> PartialEq for HashConsed<T>
impl<T: PartialEq> PartialEq for HashConsed<T>
Source§impl<T> Serialize for HashConsed<T>where
T: Serialize,
impl<T> Serialize for HashConsed<T>where
T: Serialize,
impl<T: Eq> Eq for HashConsed<T>
impl<T> StructuralPartialEq for HashConsed<T>
Auto Trait Implementations§
impl<T> Freeze for HashConsed<T>
impl<T> RefUnwindSafe for HashConsed<T>where
T: RefUnwindSafe,
impl<T> Send for HashConsed<T>
impl<T> Sync for HashConsed<T>
impl<T> Unpin for HashConsed<T>
impl<T> UnwindSafe for HashConsed<T>where
T: RefUnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.§impl<I, T> ExtractContext<I, ()> for T
impl<I, T> ExtractContext<I, ()> for T
§fn extract_context(self, _original_input: I)
fn extract_context(self, _original_input: I)
Given the context attached to a nom error, and given the original
input to the nom parser, extract more the useful context information. Read more
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<I> RecreateContext<I> for I
impl<I> RecreateContext<I> for I
§fn recreate_context(_original_input: I, tail: I) -> I
fn recreate_context(_original_input: I, tail: I) -> I
Given the original input, as well as the context reported by nom,
recreate a context in the original string where the error occurred. Read more