commit | 95cb4d5e3bfcf4e4a4a1fe2f9da1690f265c55cb | [log] [tgz] |
---|---|---|
author | James Farrell <[email protected]> | Mon Sep 30 22:59:20 2024 +0000 |
committer | James Farrell <[email protected]> | Mon Sep 30 22:59:20 2024 +0000 |
tree | c39246725b5517f447e3989d20a2ca6efb908a92 | |
parent | 8ddbef53040fad6c8b6ea114b900e9b86619e525 [diff] |
Migrate 25 crates to monorepo quickcheck regex-automata ryu same-file serde serde_json serde_spanned serde_test sharded-slab shlex siphasher tinyvec tinyvec_macros tokio-io-timeout toml toml_datetime toml_edit uniffi uniffi_checksum_derive uniffi_meta virtio-bindings virtio-queue virtio-vsock vsock vsprintf zerocopy-derive Bug: http://b/339424309 Test: treehugger Change-Id: I7bce6cf97ad8e47b68b138d1565cb997892df4ca
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