commit | 65747c26473e453a7fba3d21465f68bff13de059 | [log] [tgz] |
---|---|---|
author | Pierre-Clément Tosi <ptosi@google.com> | Mon Nov 28 23:40:42 2022 +0000 |
committer | Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> | Mon Nov 28 23:40:42 2022 +0000 |
tree | 01d087b988302c9f280f90279f524bcf7d7f0194 | |
parent | daecbc2192cd23153a6094c2b41aa21a82c07735 [diff] | |
parent | 6c02bf1e807648702e2ce0e8b1849b446e5d8bfe [diff] |
Add 'no_std' variant of the crate am: 6c02bf1e80 Original change: https://android-review.googlesource.com/c/platform/external/rust/crates/tinyvec/+/2318990 Change-Id: I59ebf687feb363ff8f6fdafd2eed3395983ed07a Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
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