From a65049db8fbd373382f8ff73ef7a1c07c3df10e0 Mon Sep 17 00:00:00 2001 From: Alex Auvolat Date: Mon, 6 Jun 2022 15:04:04 +0200 Subject: Simplify lmdb adapter (one less indirection) --- src/db/lmdb_adapter.rs | 33 ++++++--------------------------- 1 file changed, 6 insertions(+), 27 deletions(-) (limited to 'src') diff --git a/src/db/lmdb_adapter.rs b/src/db/lmdb_adapter.rs index 04902d7f..9173ad37 100644 --- a/src/db/lmdb_adapter.rs +++ b/src/db/lmdb_adapter.rs @@ -1,6 +1,4 @@ -use core::marker::PhantomPinned; use core::ops::Bound; -use core::pin::Pin; use core::ptr::NonNull; use std::collections::HashMap; @@ -272,7 +270,6 @@ where { tx: RoTxn<'a>, iter: Option, - _pin: PhantomPinned, } impl<'a, I> TxAndIterator<'a, I> @@ -283,22 +280,12 @@ where where F: FnOnce(&'a RoTxn<'a>) -> Result, { - let res = TxAndIterator { - tx, - iter: None, - _pin: PhantomPinned, - }; - let mut boxed = Box::pin(res); - - unsafe { - let tx = NonNull::from(&boxed.tx); - let iter = iterfun(tx.as_ref())?; + let mut res = TxAndIterator { tx, iter: None }; - let mut_ref: Pin<&mut TxAndIterator<'a, I>> = Pin::as_mut(&mut boxed); - Pin::get_unchecked_mut(mut_ref).iter = Some(iter); - } + let tx = unsafe { NonNull::from(&res.tx).as_ref() }; + res.iter = Some(iterfun(tx)?); - Ok(Box::new(TxAndIteratorPin(boxed))) + Ok(Box::new(res)) } } @@ -311,22 +298,14 @@ where } } -struct TxAndIteratorPin<'a, I: Iterator> + 'a>( - Pin>>, -); - -impl<'a, I> Iterator for TxAndIteratorPin<'a, I> +impl<'a, I> Iterator for TxAndIterator<'a, I> where I: Iterator> + 'a, { type Item = Result<(Value, Value)>; fn next(&mut self) -> Option { - let iter_ref = unsafe { - let mut_ref: Pin<&mut TxAndIterator<'a, I>> = Pin::as_mut(&mut self.0); - Pin::get_unchecked_mut(mut_ref).iter.as_mut() - }; - match iter_ref.unwrap().next() { + match self.iter.as_mut().unwrap().next() { None => None, Some(Err(e)) => Some(Err(e.into())), Some(Ok((k, v))) => Some(Ok((k.to_vec(), v.to_vec()))), -- cgit v1.2.3