ZeroTierOne/zeroidc/vendor/tinyvec
2023-03-01 14:27:19 -08:00
..
benches Revert "set gitattributes for rust & cargo so hashes dont conflict on Windows" 2023-03-01 14:27:19 -08:00
src Revert "set gitattributes for rust & cargo so hashes dont conflict on Windows" 2023-03-01 14:27:19 -08:00
src-backup Revert "set gitattributes for rust & cargo so hashes dont conflict on Windows" 2023-03-01 14:27:19 -08:00
tests Revert "set gitattributes for rust & cargo so hashes dont conflict on Windows" 2023-03-01 14:27:19 -08:00
.cargo-checksum.json RPM build fix (reverted CI changes which will need to be un-reverted or made conditional) and vendor Rust dependencies to make builds much faster in any CI system. 2022-06-08 07:32:16 -04:00
Cargo.toml RPM build fix (reverted CI changes which will need to be un-reverted or made conditional) and vendor Rust dependencies to make builds much faster in any CI system. 2022-06-08 07:32:16 -04:00
CHANGELOG.md Revert "set gitattributes for rust & cargo so hashes dont conflict on Windows" 2023-03-01 14:27:19 -08:00
compare_benchmarks.py Revert "set gitattributes for rust & cargo so hashes dont conflict on Windows" 2023-03-01 14:27:19 -08:00
gen-array-impls.sh Revert "set gitattributes for rust & cargo so hashes dont conflict on Windows" 2023-03-01 14:27:19 -08:00
LICENSE-APACHE.md Revert "set gitattributes for rust & cargo so hashes dont conflict on Windows" 2023-03-01 14:27:19 -08:00
LICENSE-MIT.md Revert "set gitattributes for rust & cargo so hashes dont conflict on Windows" 2023-03-01 14:27:19 -08:00
LICENSE-ZLIB.md Revert "set gitattributes for rust & cargo so hashes dont conflict on Windows" 2023-03-01 14:27:19 -08:00
README.md Revert "set gitattributes for rust & cargo so hashes dont conflict on Windows" 2023-03-01 14:27:19 -08:00
rustfmt.toml Revert "set gitattributes for rust & cargo so hashes dont conflict on Windows" 2023-03-01 14:27:19 -08: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