rustc/vendor/tinyvec
2022-11-15 19:41:33 +01:00
..
benches New upstream version 1.59.0+dfsg1 2022-03-29 13:22:26 +01:00
src New upstream version 1.63.0+dfsg1 2022-11-15 19:41:33 +01:00
src-backup New upstream version 1.51.0+dfsg1 2021-04-05 22:17:21 +01:00
tests New upstream version 1.63.0+dfsg1 2022-11-15 19:41:33 +01:00
.cargo-checksum.json New upstream version 1.63.0+dfsg1 2022-11-15 19:41:33 +01:00
Cargo.toml New upstream version 1.63.0+dfsg1 2022-11-15 19:41:33 +01:00
CHANGELOG.md New upstream version 1.63.0+dfsg1 2022-11-15 19:41:33 +01:00
compare_benchmarks.py New upstream version 1.59.0+dfsg1 2022-03-29 13:22:26 +01:00
gen-array-impls.sh New upstream version 1.51.0+dfsg1 2021-04-05 22:17:21 +01:00
LICENSE-APACHE.md New upstream version 1.53.0+dfsg1 2021-10-02 01:29:42 +01:00
LICENSE-MIT.md New upstream version 1.51.0+dfsg1 2021-04-05 22:17:21 +01:00
LICENSE-ZLIB.md New upstream version 1.51.0+dfsg1 2021-04-05 22:17:21 +01:00
README.md New upstream version 1.51.0+dfsg1 2021-04-05 22:17:21 +01:00
rustfmt.toml New upstream version 1.56.0~beta.4+dfsg1 2021-10-14 22:30:45 +01:00

License:Zlib Minimum Rust Version crates.io docs.rs

Unsafe-Zero-Percent

tinyvec

A 100% safe crate of vec-like types. #![forbid(unsafe_code)]

Main types are as follows:

  • ArrayVec is an array-backed vec-like data structure. It panics on overflow.
  • SliceVec is the same deal, but using a &mut [T].
  • TinyVec (alloc feature) is an enum that's either an Inline(ArrayVec) or a Heap(Vec). If a TinyVec is Inline and would overflow it automatically transitions to Heap and continues whatever it was doing.

To attain this "100% safe code" status there is one compromise: the element type of the vecs must implement Default.

For more details, please see the docs.rs documentation