From 81e9209f320366840ce9eee00db420198264548a Mon Sep 17 00:00:00 2001 From: leudz Date: Tue, 17 Dec 2024 13:35:25 +0100 Subject: [PATCH] Fix BorrowState reborrow A SharedBorrow was dropped immediately instead of being returned --- src/atomic_refcell/borrow_state.rs | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/src/atomic_refcell/borrow_state.rs b/src/atomic_refcell/borrow_state.rs index 1ddbc7b1..3a8f6ded 100644 --- a/src/atomic_refcell/borrow_state.rs +++ b/src/atomic_refcell/borrow_state.rs @@ -7,6 +7,7 @@ const MAX_FAILED_BORROWS: usize = HIGH_BIT + (HIGH_BIT >> 1); pub(super) struct BorrowState(AtomicUsize); /// Unlocks a shared borrow on drop. +#[must_use] pub struct SharedBorrow<'a>(&'a BorrowState); impl Drop for SharedBorrow<'_> { @@ -24,13 +25,12 @@ impl Clone for SharedBorrow<'_> { } /// Unlocks an exclusive borrow on drop. +#[must_use] pub struct ExclusiveBorrow<'a>(&'a BorrowState); impl ExclusiveBorrow<'_> { pub(crate) fn shared_reborrow(&self) -> SharedBorrow<'_> { - self.0.read_reborrow(); - - SharedBorrow(self.0) + self.0.read_reborrow() } } @@ -130,3 +130,18 @@ impl BorrowState { self.check_overflow(new) } } + +#[cfg(test)] +mod tests { + use super::*; + + #[test] + fn reborrow() { + let borrow = BorrowState::new(); + let write = borrow.write().unwrap(); + + let read = write.shared_reborrow(); + + assert_eq!(HIGH_BIT + 1, (read.0).0.load(Ordering::Relaxed)); + } +}