commit | 895f5fd9f3467a9ef258a823c4a89db2a6c013d2 | [log] [tgz] |
---|---|---|
author | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | Wed May 10 16:19:53 2023 +0000 |
committer | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | Wed May 10 16:19:53 2023 +0000 |
tree | b20f2866c1a76f13beb74f38d89e4f93290a0da8 | |
parent | 0447cae9a04753bda054b186f8144d0c2a2f0af7 [diff] | |
parent | a670ec81179294d145ffa702143a8ac479871f45 [diff] |
Snap for 10103804 from a670ec81179294d145ffa702143a8ac479871f45 to mainline-tzdata5-release Change-Id: I43e61e3d05c267a54a36690d8fcde84c762f93c8
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