A vector that can store items anywhere: in slices, arrays, or the heap!
GenericVec
has complete parity with Vec
, and even provides some features
that are only in nightly
on std
(like GenericVec::drain_filter
), or a more permissive
interface like GenericVec::retain
. In fact, you can trivially convert a Vec
to a
HeapVec
and back!
This crate is no_std
compatible, just turn off all default features.
std
(default) - enables you to use an allocator, andalloc
- enables you to use an allocator, for heap allocated storages
(like Vec
)nightly
- enables you to use array ([T; N]
) based storagesSliceVec
and InitSliceVec
SliceVec
and InitSliceVec
are pretty similar, you give them a slice
buffer, and they store all of thier values in that buffer. But have three major
differences between them.
SliceVec
Copy
types with InitSliceVec
InitSliceVec
as long as you stay
within it's capacity (the length of the slice you pass in)```rust use genericvec::{SliceVec, InitSliceVec, uninitarray};
let mut uninitbuffer = uninitarray!(16); let mut slicevec = SliceVec::new(&mut uninitbuffer);
assert!(slicevec.isempty()); slicevec.push(10); asserteq!(slice_vec, [10]); ```
```rust let mut initbuffer = [0xae; 16]; let mut slicevec = InitSliceVec::new(&mut init_buffer);
assert!(slicevec.isfull()); asserteq!(slicevec.pop(), 0xae); slicevec.setlen(16); assert!(slicevec.isfull()); ```
Of course if you try to push past a *SliceVec
's capacity
(the length of the slice you passed in), then it will panic.
rust
let mut init_buffer = [0xae; 16];
let mut slice_vec = InitSliceVec::new(&mut init_buffer);
slice_vec.push(0);
TypeVec
TypeVec
is an owned buffer. You can use like so:
```rust
use generic_vec::{TypeVec, gvec};
let mut vec: TypeVec assert_eq!(vec, [1, 2, 3, 4]); vec.trypush(5).expecterr("Tried to push past capacity!");
``` The second parameter specifies the buffer type, this can be any type
you want. Only the size of the type matters. There is also a defaulted
third parameter, but you should only use that if you know what you are
doing, and after reading the docs for As a neat side-effect of this framework, you can also get an efficient
On stable, you can use the The only limitation on stable is that you can only use ```rust
use generic_vec::ArrayVec; let mut array_vec = ArrayVec:: arrayvec.push(10);
arrayvec.push(20);
array_vec.push(30); asserteq!(arrayvec, [10, 20, 30]);
``` The distinction between ```rust
use generic_vec::ZSVec; struct MyType; let mut vec = ZSVec::new(); vec.push(MyType);
vec.push(MyType);
vec.push(MyType); asserteq!(vec.len(), 3);
asserteq!(std::mem::sizeofval(&vec), std::mem::size_of:: A ```rust
use genericvec::{HeapVec, gvec};
let mut vec: HeapVec assert_eq!(vec, [1, 2, 3, 4, 5, 6, 7, 8]); vec.trypush(5).expecterr("Tried to push past capacity!");
``` On Note on the documentation: if the feature exists on Note on implementation: large parts of the implementation came straight from Current version: 0.1.1 License: MIT/Apache-2.0UninitBuffer
.GenericVec
for zero-sized types, just a usize
in size! This feature
can be on stable no_std
.ArrayVec
and InitArrayVec
ArrayVec
and InitArrayVec
are just like the slice versions, but since they own their data,
they can be freely moved around, unconstrained. You can also create
a new ArrayVec
without passing in an existing buffer,
unlike the slice versions.ArrayVec
or
InitArrayVec
to construct the type. On nightly
,
you can use the type aliases ArrayVec
and
InitArrayVec
. The macros will be deprecated once
min_const_generics
hits stable.InitArrayVec
capacity up to 32. i.e. InitArrayVec![i32; 33]
doesn't work. ArrayVec
does not suffer
from this limitation because it is built atop TypeVec
.ArrayVec
and InitArrayVec
is identical to their slice counterparts.ZSVec
alloc
HeapVec
is just Vec
, but built atop GenericVec
,
meaning you get all the features of GenericVec
for free! But this
requries either the alloc
or std
feature to be enabled.nightly
nightly
* the restriction on InitArrayVec
's length goes away.
* many functions/methods become const fn
s
* a number of optimizations are enabled
* some diagnostics become betterVec
, then the documentation
is either exactly the same as Vec
or slightly adapted to better fit GenericVec
Vec
so thanks for the amazing reference std
!