commit | 0420c9a7a41cfdfc840e5aaac61dd5421e01802a | [log] [tgz] |
---|---|---|
author | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | Thu Apr 28 16:00:49 2022 +0000 |
committer | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | Thu Apr 28 16:00:49 2022 +0000 |
tree | e8c805f584b07b27ac90473666626006bbd63932 | |
parent | 38e5237d689623eacd0c1cef19d9fc79ebe2c178 [diff] | |
parent | c6cf201b6a75bbc6f0d33cfb27007753fd64817a [diff] |
Snap for 8512216 from c6cf201b6a75bbc6f0d33cfb27007753fd64817a to tm-frc-scheduling-release Change-Id: I1e56b5e729e224760b31f5193682e464b50aed63
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