use std::fmt::{Debug, Display}; use std::hash::Hash; use std::ops::{Deref, DerefMut}; use crate::iterator::ConsumedIteratorGuard; #[mutants::skip] // hashing involves RNG and is hard to test #[cfg(not(tarpaulin_include))] impl Hash for ConsumedIteratorGuard { fn hash(&self, state: &mut H) { self.guard.hash(state) } } // No implementations of Eq, PartialEq, PartialOrd, or Ord // You can't implement both PartialEq and PartialEq // It's easier to just implement neither and ask users to dereference // This is less of a problem when using the scoped lock API #[mutants::skip] #[cfg(not(tarpaulin_include))] impl Debug for ConsumedIteratorGuard { fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { Debug::fmt(&**self, f) } } impl Display for ConsumedIteratorGuard { fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { Display::fmt(&**self, f) } } impl Deref for ConsumedIteratorGuard { type Target = Guard; fn deref(&self) -> &Self::Target { &self.guard } } impl DerefMut for ConsumedIteratorGuard { fn deref_mut(&mut self) -> &mut Self::Target { &mut self.guard } } impl AsRef for ConsumedIteratorGuard { fn as_ref(&self) -> &Guard { &self.guard } } impl AsMut for ConsumedIteratorGuard { fn as_mut(&mut self) -> &mut Guard { &mut self.guard } }