Update tinyvec to 1.5.1 am: 38f28c3b88 am: 1fb6683fdb am: 63072d7e13

Original change: https://android-review.googlesource.com/c/platform/external/rust/crates/tinyvec/+/2005056

Change-Id: Icf038a5b04451ce5da32f5fde54dc9030d4ee5e0
tree: df29fa23f8ecd8a1b65de854c4e2907ee3fb5fc7
  1. .github/
  2. benches/
  3. patches/
  4. src/
  5. src-backup/
  6. tests/
  7. .cargo_vcs_info.json
  8. .gitignore
  9. Android.bp
  10. Cargo.toml
  11. Cargo.toml.orig
  12. cargo2android.json
  13. CHANGELOG.md
  14. compare_benchmarks.py
  15. gen-array-impls.sh
  16. LICENSE-APACHE.md
  17. LICENSE-MIT.md
  18. LICENSE-ZLIB.md
  19. METADATA
  20. MODULE_LICENSE_APACHE2
  21. OWNERS
  22. README.md
  23. rustfmt.toml
  24. TEST_MAPPING
README.md

License:Zlib Minimum Rust Version crates.io docs.rs

Unsafe-Zero-Percent

tinyvec

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