pub struct Decompressor<P>where
P: PageIterator,{ /* private fields */ }
Expand description
Decompressor that allows re-using the page buffer of PageIterator
.
§Implementation
The implementation depends on whether a page is compressed or not.
PageReader(a)
,CompressedPage(b)
,Decompressor(c)
,DecompressedPage(d)
§un-compressed pages:
page iter:
a
is swapped withb
decompress iter:b
is swapped withd
,b
is swapped witha
therefore:
PageReader
has its buffer backDecompressor
’s buffer is un-usedDecompressedPage
has the same data asCompressedPage
had
§compressed pages:
page iter:
a
is swapped withb
decompress iter:
b
is decompressed intoc
b
is swapped witha
c
is moved tod
- (next iteration):
d
is moved toc
therefore, while the page is available:
PageReader
has its buffer backDecompressor
’s buffer emptyDecompressedPage
has the decompressed buffer after the page is used:PageReader
has its buffer backDecompressor
has its buffer backDecompressedPage
has an empty buffer
Implementations§
source§impl<P> Decompressor<P>where
P: PageIterator,
impl<P> Decompressor<P>where
P: PageIterator,
sourcepub fn new(iter: P, buffer: Vec<u8>) -> Decompressor<P>
pub fn new(iter: P, buffer: Vec<u8>) -> Decompressor<P>
Creates a new Decompressor
.
Trait Implementations§
source§impl<P> FallibleStreamingIterator for Decompressor<P>where
P: PageIterator,
impl<P> FallibleStreamingIterator for Decompressor<P>where
P: PageIterator,
source§fn advance(&mut self) -> Result<(), Error>
fn advance(&mut self) -> Result<(), Error>
Advances the iterator to the next position. Read more
source§fn get(&self) -> Option<&<Decompressor<P> as FallibleStreamingIterator>::Item>
fn get(&self) -> Option<&<Decompressor<P> as FallibleStreamingIterator>::Item>
Returns the current element. Read more
source§fn next(&mut self) -> Result<Option<&Self::Item>, Self::Error>
fn next(&mut self) -> Result<Option<&Self::Item>, Self::Error>
Advances the iterator, returning the next element. Read more
source§fn size_hint(&self) -> (usize, Option<usize>)
fn size_hint(&self) -> (usize, Option<usize>)
Returns bounds on the number of remaining elements in the iterator.
source§fn all<F>(&mut self, f: F) -> Result<bool, Self::Error>
fn all<F>(&mut self, f: F) -> Result<bool, Self::Error>
Determines if all elements of the iterator satisfy a predicate.
source§fn any<F>(&mut self, f: F) -> Result<bool, Self::Error>
fn any<F>(&mut self, f: F) -> Result<bool, Self::Error>
Determines if any elements of the iterator satisfy a predicate.
source§fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
Borrows an iterator, rather than consuming it. Read more
source§fn count(self) -> Result<usize, Self::Error>where
Self: Sized,
fn count(self) -> Result<usize, Self::Error>where
Self: Sized,
Returns the number of remaining elements in the iterator.
source§fn filter<F>(self, f: F) -> Filter<Self, F>
fn filter<F>(self, f: F) -> Filter<Self, F>
Returns an iterator which filters elements by a predicate.
source§fn find<F>(&mut self, f: F) -> Result<Option<&Self::Item>, Self::Error>
fn find<F>(&mut self, f: F) -> Result<Option<&Self::Item>, Self::Error>
Returns the first element of the iterator which satisfies a predicate.
source§fn for_each<F>(self, f: F) -> Result<(), Self::Error>
fn for_each<F>(self, f: F) -> Result<(), Self::Error>
Calls a closure on each element of an iterator.
source§fn fuse(self) -> Fuse<Self>where
Self: Sized,
fn fuse(self) -> Fuse<Self>where
Self: Sized,
Returns an iterator which is well-behaved at the beginning and end of iteration.
source§fn map<F, B>(self, f: F) -> Map<Self, F, B>
fn map<F, B>(self, f: F) -> Map<Self, F, B>
Returns an iterator which applies a transform to elements.
source§fn map_ref<F, B>(self, f: F) -> MapRef<Self, F>
fn map_ref<F, B>(self, f: F) -> MapRef<Self, F>
Returns an iterator which applies a transform to elements. Read more
source§fn map_err<F, B>(self, f: F) -> MapErr<Self, F>
fn map_err<F, B>(self, f: F) -> MapErr<Self, F>
Returns an iterator that applies a transform to errors.
source§fn nth(&mut self, n: usize) -> Result<Option<&Self::Item>, Self::Error>
fn nth(&mut self, n: usize) -> Result<Option<&Self::Item>, Self::Error>
Returns the
nth
element of the iterator.source§fn position<F>(&mut self, f: F) -> Result<Option<usize>, Self::Error>
fn position<F>(&mut self, f: F) -> Result<Option<usize>, Self::Error>
Returns the position of the first element matching a predicate.
source§fn skip(self, n: usize) -> Skip<Self>where
Self: Sized,
fn skip(self, n: usize) -> Skip<Self>where
Self: Sized,
Returns an iterator which skips the first
n
elements.source§fn skip_while<F>(self, f: F) -> SkipWhile<Self, F>
fn skip_while<F>(self, f: F) -> SkipWhile<Self, F>
Returns an iterator which skips the first sequence of elements matching a predicate.
Auto Trait Implementations§
impl<P> Freeze for Decompressor<P>where
P: Freeze,
impl<P> RefUnwindSafe for Decompressor<P>where
P: RefUnwindSafe,
impl<P> Send for Decompressor<P>where
P: Send,
impl<P> Sync for Decompressor<P>where
P: Sync,
impl<P> Unpin for Decompressor<P>where
P: Unpin,
impl<P> UnwindSafe for Decompressor<P>where
P: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more