diff --git a/CHANGELOG.md b/CHANGELOG.md index 936faf2..4423b8f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,9 @@ # Changelog +## Unreleased + + * Implement `Hash` and `Eq` for `ResolvedNode` and `ResolvedToken` + ## `v0.12.0` * Documentation has been improved in most areas, together with a switch to a more principled module structure that allows explicitly documenting submodules. diff --git a/cstree/src/syntax/resolved.rs b/cstree/src/syntax/resolved.rs index 40e670e..500d611 100644 --- a/cstree/src/syntax/resolved.rs +++ b/cstree/src/syntax/resolved.rs @@ -5,6 +5,7 @@ use std::{ fmt, + hash::Hash, ops::{Deref, DerefMut}, sync::Arc as StdArc, }; @@ -65,6 +66,18 @@ impl DerefMut for ResolvedNode { } } +impl PartialEq for ResolvedNode { + fn eq(&self, other: &Self) -> bool { + self.syntax == other.syntax + } +} +impl Eq for ResolvedNode {} +impl Hash for ResolvedNode { + fn hash(&self, state: &mut H) { + self.syntax.hash(state); + } +} + /// Syntax tree token that is guaranteed to belong to a tree that contains an associated /// [`Resolver`](lasso::Resolver). /// # See also @@ -109,6 +122,18 @@ impl DerefMut for ResolvedToken { } } +impl PartialEq for ResolvedToken { + fn eq(&self, other: &Self) -> bool { + self.syntax == other.syntax + } +} +impl Eq for ResolvedToken {} +impl Hash for ResolvedToken { + fn hash(&self, state: &mut H) { + self.syntax.hash(state); + } +} + /// An element of the tree that is guaranteed to belong to a tree that contains an associated /// [`Resolver`](lasso::Resolver), can be either a node or a token. ///