pub struct CompressedVec<I, T> { /* private fields */ }Implementations§
Source§impl<I, T> CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
impl<I, T> CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
Sourcepub fn forced_import(
db: &Database,
name: &str,
version: Version,
) -> Result<Self>
pub fn forced_import( db: &Database, name: &str, version: Version, ) -> Result<Self>
Same as import but will reset the vec under certain errors, so be careful !
Sourcepub fn forced_import_with(options: ImportOptions<'_>) -> Result<Self>
pub fn forced_import_with(options: ImportOptions<'_>) -> Result<Self>
Same as import but will reset the vec under certain errors, so be careful !
pub fn import(db: &Database, name: &str, version: Version) -> Result<Self>
pub fn import_with(options: ImportOptions<'_>) -> Result<Self>
pub fn iter(&self) -> Result<CompressedVecIterator<'_, I, T>>
pub fn clean_iter(&self) -> Result<CleanCompressedVecIterator<'_, I, T>>
pub fn dirty_iter(&self) -> Result<DirtyCompressedVecIterator<'_, I, T>>
pub fn is_dirty(&self) -> bool
Trait Implementations§
Source§impl<I: Allocative, T: Allocative> Allocative for CompressedVec<I, T>
impl<I: Allocative, T: Allocative> Allocative for CompressedVec<I, T>
Source§impl<I, T> AnyCollectableVec for CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
impl<I, T> AnyCollectableVec for CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
fn collect_range_json_bytes( &self, from: Option<usize>, to: Option<usize>, ) -> Vec<u8> ⓘ
fn collect_range_string( &self, from: Option<usize>, to: Option<usize>, ) -> Vec<String>
fn range_count(&self, from: Option<i64>, to: Option<i64>) -> usize
fn range_weight(&self, from: Option<i64>, to: Option<i64>) -> usize
Source§impl<I, T> AnyIterableVec<I, T> for CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
impl<I, T> AnyIterableVec<I, T> for CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
fn boxed_iter(&self) -> BoxedVecIterator<'_, I, T>
fn iter(&self) -> BoxedVecIterator<'_, I, T>where
I: StoredIndex,
T: StoredRaw,
Source§impl<I, T> AnyStoredVec for CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
impl<I, T> AnyStoredVec for CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
fn db_path(&self) -> PathBuf
fn region(&self) -> &Region
fn header(&self) -> &Header
fn mut_header(&mut self) -> &mut Header
fn saved_stamped_changes(&self) -> u16
fn stored_len(&self) -> usize
fn real_stored_len(&self) -> usize
fn flush(&mut self) -> Result<()>
fn serialize_changes(&self) -> Result<Vec<u8>>
fn safe_flush(&mut self, exit: &Exit) -> Result<()>
fn update_stamp(&mut self, stamp: Stamp)
fn stamp(&self) -> Stamp
fn stamped_flush(&mut self, stamp: Stamp) -> Result<()>
Source§impl<I, T> AnyVec for CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
impl<I, T> AnyVec for CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
fn version(&self) -> Version
fn name(&self) -> &str
fn len(&self) -> usize
fn index_type_to_string(&self) -> &'static str
fn value_type_to_size_of(&self) -> usize
fn region_names(&self) -> Vec<String>
fn is_empty(&self) -> bool
fn index_to_name(&self) -> String
fn etag(&self, stamp: Stamp, to: Option<i64>) -> String
fn i64_to_usize(&self, i: i64) -> usize
Source§impl<I, T> Clone for CompressedVec<I, T>
impl<I, T> Clone for CompressedVec<I, T>
Source§impl<I, T> GenericStoredVec<I, T> for CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
impl<I, T> GenericStoredVec<I, T> for CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
fn read_(&self, index: usize, reader: &Reader<'_>) -> Result<T>
fn pushed(&self) -> &[T]
fn mut_pushed(&mut self) -> &mut Vec<T>
fn prev_pushed(&self) -> &[T]
fn mut_prev_pushed(&mut self) -> &mut Vec<T>
fn holes(&self) -> &BTreeSet<usize>
fn mut_holes(&mut self) -> &mut BTreeSet<usize>
fn prev_holes(&self) -> &BTreeSet<usize>
fn mut_prev_holes(&mut self) -> &mut BTreeSet<usize>
fn updated(&self) -> &BTreeMap<usize, T>
fn mut_updated(&mut self) -> &mut BTreeMap<usize, T>
fn prev_updated(&self) -> &BTreeMap<usize, T>
fn mut_prev_updated(&mut self) -> &mut BTreeMap<usize, T>
fn prev_stored_len(&self) -> usize
fn mut_prev_stored_len(&mut self) -> &mut usize
fn reset(&mut self) -> Result<()>
const SIZE_OF_T: usize = _
Source§fn create_reader(&self) -> Reader<'_>
fn create_reader(&self) -> Reader<'_>
Be careful with deadlocks Read more
Source§fn create_static_reader(&self) -> Reader<'static>
fn create_static_reader(&self) -> Reader<'static>
Be careful with deadlocks Read more
fn unwrap_read(&self, index: I, reader: &Reader<'_>) -> T
fn unwrap_read_(&self, index: usize, reader: &Reader<'_>) -> T
fn one_shot_read(&self, index: I) -> Result<T>
fn read(&self, index: I, reader: &Reader<'_>) -> Result<T>
fn one_shot_read_(&self, index: usize) -> Result<T>
fn get_any_or_read(&self, index: I, reader: &Reader<'_>) -> Result<Option<T>>
fn get_any_or_read_( &self, index: usize, reader: &Reader<'_>, ) -> Result<Option<T>>
fn one_shot_get_pushed_or_read(&self, index: I) -> Result<Option<T>>
fn get_pushed_or_read(&self, index: I, reader: &Reader<'_>) -> Result<Option<T>>
fn one_shot_get_pushed_or_read_(&self, index: usize) -> Result<Option<T>>
fn get_pushed_or_read_( &self, index: usize, reader: &Reader<'_>, ) -> Result<Option<T>>
fn get_pushed(&self, index: usize, stored_len: usize) -> Option<&T>
fn len_(&self) -> usize
fn pushed_len(&self) -> usize
fn push(&mut self, value: T)
fn push_if_needed(&mut self, index: I, value: T) -> Result<()>
fn forced_push_at(&mut self, index: I, value: T, exit: &Exit) -> Result<()>
fn forced_push_at_(&mut self, index: usize, value: T, exit: &Exit) -> Result<()>
fn update_or_push(&mut self, index: I, value: T) -> Result<()>
fn get_first_empty_index(&self) -> I
fn fill_first_hole_or_push(&mut self, value: T) -> Result<I>
fn take(&mut self, index: I, reader: &Reader<'_>) -> Result<Option<T>>
fn delete(&mut self, index: I)
fn update(&mut self, index: I, value: T) -> Result<()>
fn update_(&mut self, index: usize, value: T) -> Result<()>
fn reset_(&mut self) -> Result<()>
fn validate_computed_version_or_reset(&mut self, version: Version) -> Result<()>
fn is_pushed_empty(&self) -> bool
fn has(&self, index: I) -> bool
fn has_(&self, index: usize) -> bool
fn truncate_if_needed(&mut self, index: I) -> Result<()>
fn truncate_if_needed_(&mut self, index: usize) -> Result<()>
fn truncate_if_needed_with_stamp( &mut self, index: I, stamp: Stamp, ) -> Result<()>
fn deserialize_then_undo_changes(&mut self, bytes: &[u8]) -> Result<()>
fn stamped_flush_maybe_with_changes( &mut self, stamp: Stamp, with_changes: bool, ) -> Result<()>
fn changes_path(&self) -> PathBuf
fn stamped_flush_with_changes(&mut self, stamp: Stamp) -> Result<()>
fn rollback_before(&mut self, stamp: Stamp) -> Result<Stamp>
fn is_dirty(&mut self) -> bool
fn rollback(&mut self) -> Result<()>
fn reset_unsaved(&mut self)
fn collect_holed(&self) -> Result<Vec<Option<T>>>
fn collect_holed_range( &self, from: Option<usize>, to: Option<usize>, ) -> Result<Vec<Option<T>>>
fn vec_region_name(&self) -> String
fn vec_region_name_(name: &str) -> String
fn holes_region_name(&self) -> String
fn holes_region_name_(name: &str) -> String
Source§impl<'a, I, T> IntoIterator for &'a CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
impl<'a, I, T> IntoIterator for &'a CompressedVec<I, T>where
I: StoredIndex,
T: StoredCompressed,
Auto Trait Implementations§
impl<I, T> Freeze for CompressedVec<I, T>
impl<I, T> !RefUnwindSafe for CompressedVec<I, T>
impl<I, T> Send for CompressedVec<I, T>
impl<I, T> Sync for CompressedVec<I, T>
impl<I, T> Unpin for CompressedVec<I, T>
impl<I, T> !UnwindSafe for CompressedVec<I, T>
Blanket Implementations§
Source§impl<I, T, U> AnyCloneableIterableVec<I, T> for Uwhere
U: 'static + AnyIterableVec<I, T> + Clone,
impl<I, T, U> AnyCloneableIterableVec<I, T> for Uwhere
U: 'static + AnyIterableVec<I, T> + Clone,
fn boxed_clone(&self) -> Box<dyn AnyCloneableIterableVec<I, T>>
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<I, T, V> CollectableVec<I, T> for V
impl<I, T, V> CollectableVec<I, T> for V
fn iter_range( &self, from: Option<usize>, to: Option<usize>, ) -> impl Iterator<Item = T>
fn iter_signed_range( &self, from: Option<i64>, to: Option<i64>, ) -> impl Iterator<Item = T>
fn collect(&self) -> Vec<T>
fn collect_range(&self, from: Option<usize>, to: Option<usize>) -> Vec<T>
fn collect_signed_range(&self, from: Option<i64>, to: Option<i64>) -> Vec<T>
fn collect_range_json_bytes( &self, from: Option<usize>, to: Option<usize>, ) -> Vec<u8> ⓘ
fn collect_range_string( &self, from: Option<usize>, to: Option<usize>, ) -> Vec<String>
fn i64_to_usize_(i: i64, len: usize) -> usize
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more