[automerged blank] Make crate vendor available 2p: 57e7b291ab

Blank merge reason: Change-Id Id9d56df3dbf101899054a42e0eba6e024eb9de7e with SHA-1 6faa01ec63 is in history

Original change: https://googleplex-android-review.googlesource.com/c/platform/external/rust/crates/getrandom/+/20341511

Bug: 235777894
Bug: 245578454
Change-Id: I36f9f92c57a73506c70096688c43a2e123f1ca14
Merged-In: Id9d56df3dbf101899054a42e0eba6e024eb9de7e
tree: 7ca8a52775a815af5c02e5f1c23444c10e109e81
  1. benches/
  2. src/
  3. tests/
  4. .cargo_vcs_info.json
  5. Android.bp
  6. Cargo.toml
  7. Cargo.toml.orig
  8. cargo2android.json
  9. CHANGELOG.md
  10. LICENSE-APACHE
  11. LICENSE-MIT
  12. METADATA
  13. MODULE_LICENSE_APACHE2
  14. OWNERS
  15. README.md
  16. TEST_MAPPING
README.md

getrandom

Build Status Crate Documentation Dependency Status Downloads License

A Rust library for retrieving random data from (operating) system source. It is assumed that system always provides high-quality cryptographically secure random data, ideally backed by hardware entropy sources. This crate derives its name from Linux‘s getrandom function, but is cross platform, roughly supporting the same set of platforms as Rust’s std lib.

This is a low-level API. Most users should prefer using high-level random-number library like rand.

Usage

Add this to your Cargo.toml:

[dependencies]
getrandom = "0.2"

Then invoke the getrandom function:

fn get_random_buf() -> Result<[u8; 32], getrandom::Error> {
    let mut buf = [0u8; 32];
    getrandom::getrandom(&mut buf)?;
    Ok(buf)
}

For more information about supported targets, entropy sources, no_std targets, crate features, WASM support and Custom RNGs see the getrandom documentation and getrandom::Error documentation.

Minimum Supported Rust Version

This crate requires Rust 1.34.0 or later.

License

The getrandom library is distributed under either of

at your option.