Struct BTree

Source
pub struct BTree<S, C, G> { /* private fields */ }
Expand description

A B+Tree

Implementations§

Source§

impl<S, C, G> BTree<S, C, G>
where S: Schema, C: Collate<Value = S::Value>,

Source

pub fn schema(&self) -> &S

Borrow the Schema of this BTree.

Source§

impl<S, C, FE, G> BTree<S, C, G>
where S: Schema, C: Collate<Value = S::Value>, FE: AsType<Node<Vec<Vec<S::Value>>>> + Send + Sync, G: DirDeref<Entry = FE>, Node<Vec<Vec<S::Value>>>: FileLoad + Debug,

Source

pub async fn contains(&self, key: &[S::Value]) -> Result<bool, Error>

Return true if this B+Tree contains the given key.

Source

pub async fn count<BV>(&self, range: &Range<BV>) -> Result<u64, Error>
where BV: Borrow<S::Value>,

Count how many keys lie within the given range of this B+Tree.

Source

pub async fn first<BV>( &self, range: Range<BV>, ) -> Result<Option<Key<S::Value>>, Error>
where BV: Borrow<S::Value>,

Return the first key in this B+Tree within the given range, if any.

Source

pub async fn last<BV>( &self, range: Range<BV>, ) -> Result<Option<Key<S::Value>>, Error>
where BV: Borrow<S::Value>,

Return the last key in this B+Tree with the given prefix, if any.

Source

pub async fn is_empty<R: Borrow<Range<S::Value>>>( &self, range: R, ) -> Result<bool, Error>

Return true if the given range of this B+Tree contains zero keys.

Source§

impl<S, C, FE, G> BTree<S, C, G>
where S: Schema, C: Collate<Value = S::Value> + Clone + Send + Sync + 'static, FE: AsType<Node<Vec<Vec<S::Value>>>> + Send + Sync + 'static, G: DirDeref<Entry = FE> + Clone + Send + Sync + 'static, Node<Vec<Vec<S::Value>>>: FileLoad + Debug,

Source

pub async fn keys<BV>( self, range: Range<BV>, reverse: bool, ) -> Result<Keys<S::Value>, Error>
where BV: Borrow<S::Value> + Clone + Send + Sync + 'static,

Construct a Stream of all the keys in the given range of this B+Tree.

Source

pub async fn groups<BV>( self, range: Range<BV>, n: usize, reverse: bool, ) -> Result<Keys<S::Value>, Error>
where BV: Borrow<S::Value> + Clone + Send + Sync + 'static,

Construct a Stream of unique length-n prefixes within the given range.

Source

pub async fn is_valid(self) -> Result<bool, Error>

Source§

impl<S, C, FE> BTree<S, C, DirWriteGuardOwned<FE>>

Source

pub fn downgrade(self) -> BTreeReadGuard<S, C, FE>

Downgrade this BTreeWriteGuard into a BTreeReadGuard.

Source§

impl<S, C, FE> BTree<S, C, DirWriteGuardOwned<FE>>
where S: Schema + Send + Sync, C: Collate<Value = S::Value> + Send + Sync, FE: AsType<Node<Vec<Vec<S::Value>>>> + Send + Sync, Node<Vec<Vec<S::Value>>>: FileLoad,

Source

pub async fn delete<V>(&mut self, key: &[V]) -> Result<bool, Error>
where V: Borrow<S::Value> + Send + Sync,

Delete the given key from this B+Tree.

Source

pub async fn insert(&mut self, key: Vec<S::Value>) -> Result<bool, Error>

Insert the given key into this B+Tree. Return false if te given key is already present.

Source

pub async fn truncate(&mut self) -> Result<(), Error>

Delete all the keys in this BTree.

Source§

impl<S, C, FE> BTree<S, C, DirWriteGuardOwned<FE>>
where S: Schema + Send + Sync, C: Collate<Value = S::Value> + Clone + Send + Sync + 'static, FE: AsType<Node<Vec<Vec<S::Value>>>> + Send + Sync + 'static, Node<Vec<Vec<S::Value>>>: FileLoad,

Source

pub async fn merge<G>(&mut self, other: BTree<S, C, G>) -> Result<(), Error>
where G: DirDeref<Entry = FE> + Clone + Send + Sync + 'static,

Merge the keys from the other B+Tree range into this one.

The source B+Tree must have an identical schema and collation.

Source

pub async fn delete_all<G>( &mut self, other: BTree<S, C, G>, ) -> Result<(), Error>
where G: DirDeref<Entry = FE> + Clone + Send + Sync + 'static,

Delete the keys in the other B+Tree from this one.

The source B+Tree must have an identical schema and collation.

Trait Implementations§

Source§

impl<S, C, G> Clone for BTree<S, C, G>
where C: Clone, G: Clone,

Source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<S: Debug, C, G> Debug for BTree<S, C, G>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<S, C, G> Freeze for BTree<S, C, G>
where G: Freeze, C: Freeze,

§

impl<S, C, G> RefUnwindSafe for BTree<S, C, G>

§

impl<S, C, G> Send for BTree<S, C, G>
where G: Send, S: Sync + Send, C: Send,

§

impl<S, C, G> Sync for BTree<S, C, G>
where G: Sync, S: Sync + Send, C: Sync,

§

impl<S, C, G> Unpin for BTree<S, C, G>
where G: Unpin, C: Unpin,

§

impl<S, C, G> UnwindSafe for BTree<S, C, G>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<F, T> CastFrom<F> for T
where T: From<F>,

Source§

fn cast_from(f: F) -> T

Cast an instance of T into an instance of Self.
Source§

impl<T, F> CastInto<F> for T
where F: CastFrom<T>,

Source§

fn cast_into(self) -> F

Cast an instance of Self into an instance of T.
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<F> Match for F

Source§

fn matches<T>(&self) -> bool
where T: TryCastFrom<Self>,

Returns true if self can be cast into the target type T.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<F, T> TryCastFrom<F> for T
where T: CastFrom<F>,

Source§

fn can_cast_from(_: &F) -> bool

Test if value can be cast into Self.
Source§

fn opt_cast_from(f: F) -> Option<T>

Returns Some(Self) if the source value can be cast into Self, otherwise None.
Source§

fn try_cast_from<Err, OnErr>(value: T, on_err: OnErr) -> Result<Self, Err>
where OnErr: FnOnce(&T) -> Err,

Returns Ok(Self) if the source value can be cast into Self, otherwise calls on_err.
Source§

impl<F, T> TryCastInto<T> for F
where T: TryCastFrom<F>,

Source§

fn can_cast_into(&self) -> bool

Test if self can be cast into T.
Source§

fn opt_cast_into(self) -> Option<T>

Returns Some(T) if self can be cast into T, otherwise None.
Source§

fn try_cast_into<Err, OnErr>(self, on_err: OnErr) -> Result<T, Err>
where OnErr: FnOnce(&Self) -> Err,

Returns Ok(T) if self can be cast into T, otherwise calls on_err.
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.