| commit | aa2bdcd269fdf3d25c010e0b883c7277b0bf130d | [log] [tgz] |
|---|---|---|
| author | Android Build Coastguard Worker <[email protected]> | Thu Apr 28 16:00:29 2022 +0000 |
| committer | Android Build Coastguard Worker <[email protected]> | Thu Apr 28 16:00:29 2022 +0000 |
| tree | e8c805f584b07b27ac90473666626006bbd63932 | |
| parent | d20e4a1e973e23a3f582e90eb4ed675b07d7f100 [diff] | |
| parent | c6cf201b6a75bbc6f0d33cfb27007753fd64817a [diff] |
Snap for 8512216 from c6cf201b6a75bbc6f0d33cfb27007753fd64817a to tm-frc-os-statsd-release Change-Id: I3181588ea694fb91f94bb687d913f04eb37b2aaa
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