From bf0b861619d378c6e6f571a1709697d18987b21d Mon Sep 17 00:00:00 2001 From: Mica White Date: Thu, 14 Mar 2024 22:00:08 -0400 Subject: Fix another bug --- src/lockable.rs | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) (limited to 'src/lockable.rs') diff --git a/src/lockable.rs b/src/lockable.rs index 1b1c15c..611f0a0 100644 --- a/src/lockable.rs +++ b/src/lockable.rs @@ -62,15 +62,15 @@ unsafe impl<'a, T: Lockable<'a>> Lockable<'a> for &T { type Output = T::Output; fn get_ptrs(&self) -> Vec { - (*self).get_ptrs() + (**self).get_ptrs() } unsafe fn lock(&'a self) -> Self::Output { - (*self).lock() + (**self).lock() } unsafe fn try_lock(&'a self) -> Option { - (*self).try_lock() + (**self).try_lock() } } @@ -501,7 +501,7 @@ unsafe impl<'a, T: Lockable<'a>, const N: usize> Lockable<'a> for [T; N] { } outputs[0].write(self[0].lock()); - for i in 0..N { + for i in 1..N { match self[i].try_lock() { Some(guard) => outputs[i].write(guard), None => { @@ -529,7 +529,7 @@ unsafe impl<'a, T: Lockable<'a>, const N: usize> Lockable<'a> for [T; N] { } let mut outputs = MaybeUninit::<[MaybeUninit; N]>::uninit().assume_init(); - for i in 0..N { + for i in 1..N { match self[i].try_lock() { Some(guard) => outputs[i].write(guard), None => { @@ -563,7 +563,7 @@ unsafe impl<'a, T: Lockable<'a>> Lockable<'a> for Box<[T]> { let mut outputs = Vec::with_capacity(self.len()); outputs.push(self[0].lock()); - for lock in self.iter() { + for lock in self.iter().skip(1) { match lock.try_lock() { Some(guard) => { outputs.push(guard); @@ -613,7 +613,7 @@ unsafe impl<'a, T: Lockable<'a>> Lockable<'a> for Vec { let mut outputs = Vec::with_capacity(self.len()); outputs.push(self[0].lock()); - for lock in self { + for lock in self.iter().skip(1) { match lock.try_lock() { Some(guard) => { outputs.push(guard); -- cgit v1.2.3