Rand

Build Status Build Status Latest version Documentation Minimum rustc version

A Rust library for random number generators and other randomness functionality.

See also:

Documentation: master branch, by release

Usage

Add this to your Cargo.toml:

toml [dependencies] rand = "0.5.0-pre.0"

and this to your crate root:

```rust extern crate rand;

// example usage: use rand::{Rng, threadrng}; let x: f64 = threadrng().gen(); ```

Versions

Version 0.5 is available as a pre-release and contains many breaking changes. See the Upgrade Guide for guidance on updating from previous versions.

Version 0.4 was released in December 2017. It contains almost no breaking changes since the 0.3 series.

For more details, see the changelog.

Compatibility shims

As of now there is no compatibility shim between Rand 0.4 and 0.5. It is also not entirely obvious how to make one due to the large differences between the two versions, although it would be possible to implement the new RngCore for any implementation of the old Rng (or vice-versa; unfortunately not both as that would result in circular implementation). If we implement a compatibility shim it will be optional (opt-in via a feature).

There is a compatibility shim from 0.3 to 0.4 forcibly upgrading all Rand 0.3 users; this is largely due to the small differences between the two versions.

Rust version requirements

The 0.5 release of Rand will require Rustc version 1.22 or greater. Rand 0.4 and 0.3 (since approx. June 2017) require Rustc version 1.15 or greater. Subsets of the Rand code may work with older Rust versions, but this is not supported.

Travis CI always has a build with a pinned version of Rustc matching the oldest supported Rust release. The current policy is that this can be updated in any Rand release if required, but the change must be noted in the changelog.

Functionality

The rand_core crate provides:

The rand crate provides:

Crate Features

By default, Rand is built with all stable features available. The following optional features are available:

Testing

Unfortunately, cargo test does not test everything. The following tests are recommended:

```

Basic tests for Rand and sub-crates

cargo test --all

Test no_std support

cargo test --tests --no-default-features

Test no_std+alloc support

cargo test --tests --no-default-features --features alloc

Test log and serde support

cargo test --features serde-1,log

Test 128-bit support (requires nightly)

cargo test --all --features nightly

Benchmarks (requires nightly)

cargo bench

or just to test the benchmark code:

cargo test --benches ```

License

Rand is distributed under the terms of both the MIT license and the Apache License (Version 2.0).

See LICENSE-APACHE and LICENSE-MIT for details.