commit | 0cf0ca3685549b2ace16d82369c5444430ee9d27 | [log] [tgz] |
---|---|---|
author | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | Thu May 23 23:15:27 2024 +0000 |
committer | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | Thu May 23 23:15:27 2024 +0000 |
tree | ca65f557f9439b1d5ee7d3726dbb630f681455c1 | |
parent | bc2339de868009a57404a6c66c97516bd356019a [diff] | |
parent | 1f4ebb598b202c5dcbfd8286b01656fd75e86297 [diff] |
Snap for 11881322 from 1f4ebb598b202c5dcbfd8286b01656fd75e86297 to 24Q3-release Change-Id: I2df2e78ddea781b03053848537a97b46e865ef6c
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