refactor: move iterator trait to parent mod

Signed-off-by: Alex Chi <iskyzh@gmail.com>
This commit is contained in:
Alex Chi
2022-12-24 18:25:41 -05:00
parent 7a571a7c7d
commit d8cc9b2cf8
22 changed files with 79 additions and 49 deletions

View File

@@ -1,15 +0,0 @@
use anyhow::Result;
pub trait StorageIterator {
/// Get the current value.
fn value(&self) -> &[u8];
/// Get the current key.
fn key(&self) -> &[u8];
/// Check if the current iterator is valid.
fn is_valid(&self) -> bool;
/// Move to the next position.
fn next(&mut self) -> Result<()>;
}

View File

@@ -4,7 +4,7 @@ use std::collections::BinaryHeap;
use anyhow::Result;
use super::impls::StorageIterator;
use super::StorageIterator;
struct HeapWrapper<I: StorageIterator>(pub usize, pub Box<I>);

View File

@@ -1,7 +1,7 @@
use anyhow::Result;
use bytes::Bytes;
use super::impls::StorageIterator;
use super::StorageIterator;
pub mod merge_iterator_test;
pub mod two_merge_iterator_test;

View File

@@ -1,6 +1,6 @@
use anyhow::Result;
use super::impls::StorageIterator;
use super::StorageIterator;
/// Merges two iterators of different types into one. If the two iterators have the same key, only
/// produce the key once and prefer the entry from A.