#pin #vec-like #vec #element #pinned #move

pinned_vec

Vec-like data structure whose elements never move

2 releases

0.1.1 Nov 25, 2021
0.1.0 Nov 25, 2021

#1495 in Data structures

Download history 130/week @ 2025-03-19 10/week @ 2025-03-26 42/week @ 2025-04-02 69/week @ 2025-04-09 463/week @ 2025-04-16 3195/week @ 2025-04-23 984/week @ 2025-04-30 373/week @ 2025-05-07 2964/week @ 2025-05-14 16/week @ 2025-05-21 4/week @ 2025-05-28 25/week @ 2025-06-04 9/week @ 2025-06-11 13/week @ 2025-06-18 22/week @ 2025-06-25 40/week @ 2025-07-02

87 downloads per month
Used in 3 crates (2 directly)

MPL-2.0 license

9KB
180 lines

PinnedVec

crates.io crates.io

Vec-like structure whose elements never move.

Normal Vec holds all its content in one contigious region, and moves when it needs to expand. PinnedVec holds several smaller sub-vector, each of which never moves. The first sub-vector is of capacity 1, the second 2, the third 4, the nth 2^(n-1).

Example Usage

use pinned_vec::PinnedVec;
use std::pin::Pin;
let mut v = PinnedVec::new();
v.push(5);
{
	let r: Pin<&i32> = v.get(0).unwrap();
	assert_eq!(*r, 5);
}
{
	let r: Pin<&mut i32> = v.get_mut(0).unwrap();
	assert_eq!(*r, 5);
}
assert_eq!(v.len(), 1);
v.pop();
v.push(7);
v.push(8);
v.replace(0, 6);
assert_eq!(*v.get(0).unwrap(), 6);
assert_eq!(*v.get(1).unwrap(), 8);

No runtime deps