Struct Collection

Source
pub struct Collection<'a, T> { /* private fields */ }
Expand description

Represents a collection of documents.

It is the main API for data managment for Keratin.

Implementations§

Source§

impl<'a, T: Serialize + Clone + for<'de> Deserialize<'de>> Collection<'a, T>

Source

pub fn get(&mut self, k: &str) -> Option<T>

Returns an entry of the database given the respective key, or None if the key corresponds to no known entries

Source

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

Source

pub fn insert(&mut self, key: &str, entry: T) -> Result<()>

Insert an entry into the database given an Entry

§Note

This does not cache the entry automaticaly

Source

pub fn delete(&mut self, query: &str) -> Result<()>

Delete a entry in the database given the key.

This deletes from both the cache and non-volatile storage.

§Note

In the future this will use a query string to find what multiple elements to delete

§Return

Returns an Error EntryNotFound if the key does not match any entry

Source

pub fn modify(&mut self, key: &str, new_entry: T) -> Result<()>

Source

pub fn configure( path: Option<&str>, se: &'a dyn StorageEngine<T>, ) -> Result<Collection<'a, T>>

A function to initialize the collection using the path of a configuration file

§Arguments
  • path - An Option with a Path. If this is None, Keratin will use the default config file path (eg. db/keratin.toml)

  • se - The Storage Engine of the database. Right now only LocalFsStorage is implemented into the crate, but in theory anything that implements the StorageEngine trait could be passed as the parameter.

§Errors

This returns an error if the config file is not found OR if the folder doesn’t have the right permitions

Source

pub fn iter_mut(&mut self) -> Result<IterMut<'_, String, T>>

Trait Implementations§

Source§

impl<'a, T: Clone> Clone for Collection<'a, T>

Source§

fn clone(&self) -> Collection<'a, T>

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

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

Performs copy-assignment from source. Read more

Auto Trait Implementations§

§

impl<'a, T> Freeze for Collection<'a, T>

§

impl<'a, T> !RefUnwindSafe for Collection<'a, T>

§

impl<'a, T> !Send for Collection<'a, T>

§

impl<'a, T> !Sync for Collection<'a, T>

§

impl<'a, T> Unpin for Collection<'a, T>
where T: Unpin,

§

impl<'a, T> !UnwindSafe for Collection<'a, T>

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<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<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<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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V