Upgrade rust/crates/tinyvec to 1.1.1 am: 64e0888754 am: 2fca6e7303 am: f9d9c987ce am: 642665c072

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

MUST ONLY BE SUBMITTED BY AUTOMERGER

Change-Id: Ie6b6e9a9db086b5f3f7ed6683a18441700c6eef0
tree: 8aeebd7a62744e274aee61db3a48f240947b1b49
  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. CHANGELOG.md
  13. gen-array-impls.sh
  14. LICENSE-APACHE.md
  15. LICENSE-MIT.md
  16. LICENSE-ZLIB.md
  17. METADATA
  18. MODULE_LICENSE_APACHE2
  19. OWNERS
  20. README.md
  21. rustfmt.toml
  22. 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