Struct Storage

Source
pub struct Storage {
    pub entries: HashMap<String, Entry>,
}

Fields§

§entries: HashMap<String, Entry>

Implementations§

Source§

impl Storage

Source

pub fn new(entries: HashMap<String, Entry>) -> Self

Create storage

Source

pub fn add<K: ToString, T: Into<Entry>>( &mut self, key: K, entry: T, ) -> Option<Entry>

Add new entry to storage

Works as HashMap::insert method, so will return Some(Entry) if it replaced older value

use kinda_virtual_fs::*;
 
let mut storage = Storage::default();
 
storage.add("example 1", "Hello, World!");
storage.add("example 2", Entry::new("Also accepts Entry struct"));
Source

pub fn get<T: ToString>(&self, key: T) -> Option<&Entry>

Get entry with the given key

Source

pub fn remove<T: ToString>(&mut self, key: T) -> Option<Entry>

Remove entry with the given key

Source

pub fn map<T: ToString>(&self, key: T) -> Result<String>

Try to map entry with specific key

use kinda_virtual_fs::*;
 
let mut storage = Storage::default();
 
storage.add("example", "Hello, World!");
 
let file_path = storage.map("example").expect("Failed to map entry");
let file_content = std::fs::read_to_string(file_path).expect("Failed to read mapped entry");
 
assert_eq!(&file_content, "Hello, World!");
Source

pub fn unmap<T: ToString>(&self, key: T) -> Result<()>

Unmap entry with specific key

Will return Ok(()) if there’s no entry with specified key

Entry will be automatically unmapped when its value is no more needed

§Manual unmapping
use kinda_virtual_fs::*;
 
let mut storage = Storage::default();
 
storage.add("example", "Hello, World!");
 
let path = storage.map("example").unwrap();
 
assert_eq!(std::path::Path::new(&path).exists(), true);
 
storage.unmap("example");
 
assert_eq!(std::path::Path::new(&path).exists(), false);
§Automatic unmapping
use kinda_virtual_fs::*;
 
let mut storage = Storage::default();
 
storage.add("example", "Hello, World!");
 
let path = storage.map("example").unwrap();
 
assert_eq!(std::path::Path::new(&path).exists(), true);
 
storage.remove("example");
 
assert_eq!(std::path::Path::new(&path).exists(), false);

Trait Implementations§

Source§

impl Clone for Storage

Source§

fn clone(&self) -> Storage

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

impl Debug for Storage

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Default for Storage

Source§

fn default() -> Storage

Returns the “default value” for a type. Read more

Auto Trait Implementations§

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.