commit | 7ea82c332b53cf96e691b3c6f5b9ee4ddd75b1ad | [log] [tgz] |
---|---|---|
author | Luke Huang <[email protected]> | Wed May 12 11:20:36 2021 +0000 |
committer | Automerger Merge Worker <[email protected]> | Wed May 12 11:20:36 2021 +0000 |
tree | 374e6263abc26a82e70c06ffcb32122ace1036af | |
parent | fc512385439689a6c4a6243c500757bb7c031eb6 [diff] | |
parent | 863b9e67c6ec84ab45a3dcf8673ecb7199c61a52 [diff] |
Make libtinyvec available to DnsResolver am: c5df0d2700 am: 412b0b2480 am: e8e7788f61 am: 863b9e67c6 Original change: https://android-review.googlesource.com/c/platform/external/rust/crates/tinyvec/+/1705166 Change-Id: I83252ed083b95c0708ae91e77d9f982532c12693
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