Struct fmmap::raw::MemoryMmapFile

source ·
pub struct MemoryMmapFile { /* private fields */ }
Available on crate feature sync only.
Expand description

Use Bytes to mock a mmap, which is useful for test and in-memory storage engine.

Implementations§

source§

impl MemoryMmapFile

source

pub fn new<P: AsRef<Path>>(path: P, data: Bytes) -> Self

Create a MemoryMmapFile

Examples
use bytes::{BufMut, BytesMut};
use fmmap::raw::MemoryMmapFile;

let mut data = BytesMut::with_capacity(100);
data.put_slice("some data...".as_bytes());
MemoryMmapFile::new("foo.mem", data.freeze());
source

pub fn from_vec<P: AsRef<Path>>(path: P, src: Vec<u8>) -> Self

Create a MemoryMmapFile from Vec

Examples
use fmmap::raw::MemoryMmapFile;

let data = (0..=255u8).collect::<Vec<_>>();
MemoryMmapFile::from_vec("foo.mem", data);
source

pub fn from_string<P: AsRef<Path>>(path: P, src: String) -> Self

Create a MemoryMmapFile from String

Examples
use fmmap::raw::MemoryMmapFile;

let data: &'static str = "some data...";
MemoryMmapFile::from_string("foo.mem", data.to_string());
source

pub fn from_slice<P: AsRef<Path>>(path: P, src: &'static [u8]) -> Self

Create a MemoryMmapFile from static slice

Examples
use bytes::Bytes;
use fmmap::raw::MemoryMmapFile;

let data: &'static [u8] = "some data...".as_bytes();
MemoryMmapFile::from_slice("foo.mem", data);
source

pub fn from_str<P: AsRef<Path>>(path: P, src: &'static str) -> Self

Create a MemoryMmapFile from static str

Examples
use bytes::Bytes;
use fmmap::raw::MemoryMmapFile;

let data: &'static str = "some data...";
MemoryMmapFile::from_str("foo.mem", data);
source

pub fn copy_from_slice<P: AsRef<Path>>(path: P, src: &[u8]) -> Self

Create a MemoryMmapFile by copy from slice

Examples
use fmmap::raw::MemoryMmapFile;

MemoryMmapFile::copy_from_slice("foo.mem", "some data...".as_bytes());
source

pub fn into_bytes(self) -> Bytes

Returns the inner bytes

Examples
use bytes::Bytes;
use fmmap::raw::MemoryMmapFile;

let b1 = MemoryMmapFile::copy_from_slice("foo.mem", "some data...".as_bytes()).into_bytes();
assert_eq!(b1, Bytes::copy_from_slice("some data...".as_bytes()));

Trait Implementations§

source§

impl Clone for MemoryMmapFile

source§

fn clone(&self) -> MemoryMmapFile

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 From<MemoryMmapFile> for MmapFile

source§

fn from(file: MemoryMmapFile) -> Self

Converts to this type from the input type.
source§

impl MmapFileExt for MemoryMmapFile

source§

fn len(&self) -> usize

Returns the current mmap length
source§

fn as_slice(&self) -> &[u8]

Returns the underlying slice of the mmap
source§

fn path(&self) -> &Path

Returns the path of the inner file.
source§

fn is_exec(&self) -> bool

Whether the mmap is executable.
source§

fn metadata(&self) -> Result<MetaData>

Returns the metadata of file metadata Read more
source§

fn lock_exclusive(&self) -> Result<()>

Locks the file for shared usage, blocking if the file is currently locked exclusively. Read more
source§

fn lock_shared(&self) -> Result<()>

Locks the file for exclusive usage, blocking if the file is currently locked. Read more
source§

fn try_lock_exclusive(&self) -> Result<()>

Locks the file for shared usage, or returns a an error if the file is currently locked (see lock_contended_error). Read more
source§

fn try_lock_shared(&self) -> Result<()>

Locks the file for shared usage, or returns a an error if the file is currently locked (see lock_contended_error).Locks the file for shared usage, or returns a an error if the file is currently locked (see lock_contended_error). Read more
source§

fn unlock(&self) -> Result<()>

Unlocks the file. Read more
source§

fn is_empty(&self) -> bool

Returns the mmap is empty of not.
source§

fn slice(&self, offset: usize, sz: usize) -> &[u8]

slice returns data starting from offset off of size sz. Read more
source§

fn bytes(&self, offset: usize, sz: usize) -> Result<&[u8]>

bytes returns data starting from offset off of size sz. Read more
source§

fn path_buf(&self) -> PathBuf

Returns the path buf of the inner file.
source§

fn path_lossy(&self) -> Cow<'_, str>

Returns the path lossy string of the inner file.
source§

fn path_string(&self) -> String

Returns the path string of the inner file.
source§

fn copy_all_to_vec(&self) -> Vec<u8>

Copy the content of the mmap file to Vec
source§

fn copy_range_to_vec(&self, offset: usize, len: usize) -> Vec<u8>

Copy a range of content of the mmap file to Vec
source§

fn write_all_to_new_file<P: AsRef<Path>>(&self, new_file_path: P) -> Result<()>

Write the content of the mmap file to a new file.
source§

fn write_range_to_new_file<P: AsRef<Path>>( &self, new_file_path: P, offset: usize, len: usize ) -> Result<()>

Write a range of content of the mmap file to new file.
source§

fn reader(&self, offset: usize) -> Result<MmapFileReader<'_>>

Returns a MmapFileReader which helps read data from mmap like a normal File. Read more
source§

fn range_reader(&self, offset: usize, len: usize) -> Result<MmapFileReader<'_>>

Returns a MmapFileReader base on the given offset and len, which helps read data from mmap like a normal File. Read more
source§

fn read(&self, dst: &mut [u8], offset: usize) -> usize

Read bytes to the dst buf from the offset, returns how many bytes read.
source§

fn read_exact(&self, dst: &mut [u8], offset: usize) -> Result<()>

Read the exact number of bytes required to fill buf.
source§

fn read_i8(&self, offset: usize) -> Result<i8>

Read a signed 8 bit integer from offset.
source§

fn read_i16(&self, offset: usize) -> Result<i16>

Read a signed 16 bit integer from offset in big-endian byte order.
source§

fn read_i16_le(&self, offset: usize) -> Result<i16>

Read a signed 16 bit integer from offset in little-endian byte order.
source§

fn read_isize(&self, offset: usize) -> Result<isize>

Read a signed integer from offset in big-endian byte order.
source§

fn read_isize_le(&self, offset: usize) -> Result<isize>

Read a signed integer from offset in little-endian byte order.
source§

fn read_i32(&self, offset: usize) -> Result<i32>

Read a signed 32 bit integer from offset in big-endian byte order.
source§

fn read_i32_le(&self, offset: usize) -> Result<i32>

Read a signed 32 bit integer from offset in little-endian byte order.
source§

fn read_i64(&self, offset: usize) -> Result<i64>

Read a signed 64 bit integer from offset in big-endian byte order.
source§

fn read_i64_le(&self, offset: usize) -> Result<i64>

Read a signed 64 bit integer from offset in little-endian byte order.
source§

fn read_i128(&self, offset: usize) -> Result<i128>

Read a signed 128 bit integer from offset in big-endian byte order.
source§

fn read_i128_le(&self, offset: usize) -> Result<i128>

Read a signed 128 bit integer from offset in little-endian byte order.
source§

fn read_u8(&self, offset: usize) -> Result<u8>

Read an unsigned 8 bit integer from offset.
source§

fn read_u16(&self, offset: usize) -> Result<u16>

Read an unsigned 16 bit integer from offset in big-endian.
source§

fn read_u16_le(&self, offset: usize) -> Result<u16>

Read an unsigned 16 bit integer from offset in little-endian.
source§

fn read_usize(&self, offset: usize) -> Result<usize>

Read an unsigned integer from offset in big-endian byte order.
source§

fn read_usize_le(&self, offset: usize) -> Result<usize>

Read an unsigned integer from offset in little-endian byte order.
source§

fn read_u32(&self, offset: usize) -> Result<u32>

Read an unsigned 32 bit integer from offset in big-endian.
source§

fn read_u32_le(&self, offset: usize) -> Result<u32>

Read an unsigned 32 bit integer from offset in little-endian.
source§

fn read_u64(&self, offset: usize) -> Result<u64>

Read an unsigned 64 bit integer from offset in big-endian.
source§

fn read_u64_le(&self, offset: usize) -> Result<u64>

Read an unsigned 64 bit integer from offset in little-endian.
source§

fn read_u128(&self, offset: usize) -> Result<u128>

Read an unsigned 128 bit integer from offset in big-endian.
source§

fn read_u128_le(&self, offset: usize) -> Result<u128>

Read an unsigned 128 bit integer from offset in little-endian.
source§

fn read_f32(&self, offset: usize) -> Result<f32>

Read an IEEE754 single-precision (4 bytes) floating point number from offset in big-endian byte order.
source§

fn read_f32_le(&self, offset: usize) -> Result<f32>

Read an IEEE754 single-precision (4 bytes) floating point number from offset in little-endian byte order.
source§

fn read_f64(&self, offset: usize) -> Result<f64>

Read an IEEE754 single-precision (8 bytes) floating point number from offset in big-endian byte order.
source§

fn read_f64_le(&self, offset: usize) -> Result<f64>

Read an IEEE754 single-precision (8 bytes) floating point number from offset in little-endian byte order.
source§

impl PartialEq<MemoryMmapFile> for MemoryMmapFile

source§

fn eq(&self, other: &MemoryMmapFile) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Eq for MemoryMmapFile

source§

impl StructuralEq for MemoryMmapFile

source§

impl StructuralPartialEq for MemoryMmapFile

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. 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 Twhere 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> IntoResult<T> for T

§

type Err = Infallible

source§

fn into_result(self) -> Result<T, <T as IntoResult<T>>::Err>

source§

impl<T> ToOwned for Twhere T: Clone,

§

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 Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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.