Crates.io | opaque_pool |
lib.rs | opaque_pool |
version | 0.3.2 |
created_at | 2025-06-26 06:28:28.488879+00 |
updated_at | 2025-08-28 08:26:50.330956+00 |
description | A pinned object pool that contains any type of object as long as it has a compatible memory layout |
homepage | |
repository | https://github.com/folo-rs/folo |
max_upload_size | |
id | 1726875 |
size | 248,893 |
A pinned object pool that contains any type of object as long as it has a compatible memory layout.
The pool returns super-powered pointers (Pooled<T>
) that can be copied and cloned freely, providing type-safe access to the stored values.
use std::alloc::Layout;
use opaque_pool::OpaquePool;
// Create a pool for storing values that match the layout of `u64`.
let layout = Layout::new::<u64>();
let mut pool = OpaquePool::builder().layout(layout).build();
// Insert values into the pool.
// SAFETY: The layout of u64 matches the pool's item layout.
let pooled1 = unsafe { pool.insert(42_u64) };
// SAFETY: The layout of u64 matches the pool's item layout.
let pooled2 = unsafe { pool.insert(123_u64) };
// The handles act like super-powered pointers - they can be copied freely.
let pooled1_copy = pooled1;
// Read data back from the pooled items.
let value1 = unsafe {
// SAFETY: The pointer is valid and the value was just inserted.
pooled1.ptr().read()
};
let value1_copy = unsafe {
// SAFETY: Both handles refer to the same stored value.
pooled1_copy.ptr().read()
};
assert_eq!(value1, value1_copy);
More details in the package documentation.
This is part of the Folo project that provides mechanisms for high-performance hardware-aware programming in Rust.