contiguous_mem

contiguous_mem streamlines storage and management of data stored in contiguous blocks of memory.

Crate Documentation CI Status Zlib or MIT or Apache 2.0 license

Stability

All versions prior to 1.0.0 are not considered production ready. This is my first crate and there's still a lot of edge cases I didn't get a chance to consider yet.

Prelimenary tests are in place but I don't consider them sufficient to guarantee correctness of behavior.

Key Features

Specialized implementations

You can pick and choose which implementation suits your use case best allowing you to avoid runtime cost of synchronization and additionally memory cost of safely wrapping referenced data if you don't need it.

Default implementation keeps relative offsets of stored data which are resolved on access.

Use cases

Tradeoffs

Getting Started

Add the crate to your dependencies:

toml [dependencies] contiguous_mem = { version = "0.4.*" }

Optionally enable no_std feature to use in no_std environment:

toml [dependencies] contiguous_mem = { version = "0.4.*", features = ["no_std"] }

Features

Usage

```rust use contiguous_mem::*;

[derive(Debug, Clone, Copy, PartialEq, Eq)]

struct Data { value: u32, }

fn main() { // Create a ContiguousMemory instance with a capacity of 1024 bytes and 1-byte alignment let mut memory = ContiguousMemory::new(1024);

// Store data in the memory container
let data = Data { value: 42 };
let stored_number: ContiguousMemoryRef<u64> = memory.push(22u64);
let stored_data: ContiguousMemoryRef<Data> = memory.push(data);

// Retrieve and use the stored data
assert_eq!(*stored_data.get(), data);
assert_eq!(*stored_number.get(), 22);

} ```

Note that reference types returned by store are inferred and only shown here for demonstration purposes.

For more usage examples see the examples directory.

Alternatives

Contributions

Contributions are welcome, feel free to create an issue or a pull request.

All contributions to the project are licensed under the Zlib/MIT/Apache 2.0 license unless you explicitly state otherwise.

License

This project is licensed under Zlib, MIT, or Apache-2.0 license, choose whichever suits you most.