Skip to content

Commit b45e54f

Browse files
authored
Merge branch 'master' into patch-6
2 parents 9c12ad3 + af8aa52 commit b45e54f

37 files changed

+1482
-341
lines changed

.travis.yml

Lines changed: 120 additions & 43 deletions
Original file line numberDiff line numberDiff line change
@@ -1,43 +1,118 @@
11
language: rust
22
sudo: false
33

4-
# We aim to test all the following in any combination:
5-
# - standard tests, benches, documentation, all available features
6-
# - pinned stable, latest stable, beta and nightly Rust releases
7-
# - Linux, OS X, Android, iOS, bare metal (i.e. no_std)
8-
# - x86_64, ARMv7, a Big-Endian arch (MIPS)
4+
# We support too many combinations of Rust releases, crate features, operating
5+
# systems, and architectures to even remotely test all combinations.
6+
# Yet it turns out we can test most of these independent of each other, because
7+
# they serve different goals or test different pieces of code.
8+
#
9+
# RUST RELEASES
10+
# Goal: make sure we don't use language features unavailable on a certain
11+
# version, and build without warnings.
12+
# We have different builders use 4 Rust releases, a pinned stable release,
13+
# the latest stable, beta and nightly.
14+
#
15+
# ARCHITECTURES
16+
# Goal: test against issues caused by differences in endianness, pointer sizes,
17+
# etc.
18+
# We run tests on 4 different architectures.
19+
# - x64_84, default on Travis (Linux) and AppVeyor (Windows)
20+
# - i686, second AppVeyor (Windows) configuration
21+
# - MIPS, big-endian Linux emulated with QEMU (thanks to Trust)
22+
# - ARMv7, Android emulated with QEMU (thanks to Trust)
23+
#
24+
# OPERATING SYSTEMS
25+
# Goal: test on many operating systems, to verify the OsRng code, which is
26+
# mostly architecture-independent.
27+
# We run tests on Linux, OS X, Windows, Android (emulated), and Node.js (using
28+
# cargo-web).
29+
# One builder cross-compiles for many of the remaining OSes, which ensures we
30+
# keep building, but doesn't run tests.
31+
# OSes supported by Rand but which we can't cross-compile because there
32+
# is no pre-built standard library available: Dragonfly BSD, Haiku, OpenBSD.
33+
#
34+
# CRATE FEATURES, TESTS, AND SUB-CRATES
35+
# Goal: Run unit tests, doctests, examples, and test benchmarks for all crates,
36+
# in configurations that cover all interesting combinations of features.
37+
# (`--lib` only runs unit tests just like `--tests`, but the latter is not
38+
# available in Rust 1.22.0)
39+
# Tests run on rand:
40+
# - test no_std support, but only the unit tests:
41+
# `cargo test --lib --no-default-features`
42+
# - run unit tests and doctests with all features which are available on stable:
43+
# `cargo test --features=serde1,log`
44+
# - test examples:
45+
# `cargo test --examples`
46+
# Additional tests on nightly:
47+
# - run unit tests and doctests with all features which are available on nightly:
48+
# `cargo test --all-features`
49+
# - test no_std support, including the nightly alloc feature:
50+
# cargo test --lib --no-default-features --features=alloc
51+
# - run benchmarks as tests:
52+
# `cargo test --benches --features=nightly`
53+
# Tests on subcrates:
54+
# `cargo test --package rand_core`
55+
# `cargo test --package rand_core --features=alloc` (requires nightly)
56+
# `cargo test --package rand_core --no-default-features`
57+
# `cargo test --package rand_isaac --features=serde1`
58+
# `cargo test --package rand_xorshift --features=serde1`
959
matrix:
1060
include:
1161
- rust: 1.22.0
62+
env: DESCRIPTION="pinned stable Rust release"
1263
install:
1364
script:
14-
# TODO: use --tests instead of --lib on more recent compiler
1565
- cargo test --lib --no-default-features
66+
- cargo test --features=serde1,log
67+
- cargo test --examples
68+
- cargo test --package rand_core
1669
- cargo test --package rand_core --no-default-features
17-
- cargo test --features serde1,log
70+
- cargo test --package rand_isaac --features=serde1
71+
# - cargo test --package rand_xorshift --features=serde1
72+
1873
- rust: stable
74+
env: DESCRIPTION="stable Rust release, macOS, iOS (cross-compile only)"
1975
os: osx
2076
install:
77+
- rustup target add aarch64-apple-ios
2178
script:
22-
- cargo test --tests --no-default-features
79+
- cargo test --lib --no-default-features
80+
- cargo test --features=serde1,log,i128_support
81+
- cargo test --examples
82+
- cargo test --package rand_core
2383
- cargo test --package rand_core --no-default-features
24-
- cargo test --features serde1,log
84+
- cargo test --package rand_isaac --features=serde1
85+
- cargo test --package rand_xorshift --features=serde1
86+
- cargo build --target=aarch64-apple-ios
87+
2588
- rust: beta
89+
env: DESCRIPTION="beta Rust release"
2690
install:
2791
script:
28-
- cargo test --tests --no-default-features
92+
- cargo test --lib --no-default-features
93+
- cargo test --features=serde1,log,i128_support
94+
- cargo test --examples
95+
- cargo test --package rand_core
2996
- cargo test --package rand_core --no-default-features
30-
- cargo test --features serde1,log
97+
- cargo test --package rand_isaac --features=serde1
98+
- cargo test --package rand_xorshift --features=serde1
99+
31100
- rust: nightly
101+
env: DESCRIPTION="nightly features, benchmarks, documentation"
32102
install:
33103
- cargo --list | egrep "^\s*deadlinks$" -q || cargo install cargo-deadlinks
104+
- cargo deadlinks -V
34105
before_script:
35106
- pip install 'travis-cargo<0.2' --user && export PATH=$HOME/.local/bin:$PATH
36107
script:
37-
- cargo test --tests --no-default-features --features=alloc
38-
- cargo test --package rand_core --no-default-features --features=alloc,serde1
39-
- cargo test --features serde1,log,nightly,alloc
40-
- cargo test --all --benches
108+
- cargo test --lib --no-default-features --features=alloc
109+
- cargo test --all-features
110+
- cargo test --benches --features=nightly
111+
- cargo test --examples
112+
- cargo test --package rand_core
113+
- cargo test --package rand_core --no-default-features --features=alloc
114+
- cargo test --package rand_isaac --features=serde1
115+
# - cargo test --package rand_xorshift --features=serde1
41116
# remove cached documentation, otherwise files from previous PRs can get included
42117
- rm -rf target/doc
43118
- cargo doc --no-deps --all --all-features
@@ -46,52 +121,54 @@ matrix:
46121
- travis-cargo --only nightly doc-upload
47122

48123
- rust: nightly
124+
env: DESCRIPTION="WASM via emscripten, stdweb and wasm-bindgen"
49125
install:
50126
- rustup target add wasm32-unknown-unknown
51-
# Use cargo-update since we need a real update-or-install command
52-
# Only install if not already installed:
53-
#- cargo --list | egrep "\binstall-update$" -q || cargo install cargo-update
54-
#- cargo install-update -i cargo-web
55-
# Cargo has errors with sub-commands so ignore updating for now:
127+
- rustup target add wasm32-unknown-emscripten
128+
# cargo-web takes ±10 min. to install, and cargo and cargo-update offer
129+
# no reliable update-or-install command. We ignore updating for now
130+
# (just drop the Travis' caches when necessary)
56131
- cargo --list | egrep "^\s*web$" -q || cargo install cargo-web
132+
- cargo web -V
133+
addons:
134+
chrome: stable
57135
script:
58-
- cargo web test --target wasm32-unknown-unknown --nodejs --features=stdweb
59-
60-
- rust: nightly
61-
install:
62-
- rustup target add wasm32-unknown-unknown
63-
script:
64-
- cargo build --target wasm32-unknown-unknown --features wasm-bindgen
136+
# testing wasm32-unknown-emscripten fails because of rust-lang/rust#49877
137+
- cargo build --target wasm32-unknown-emscripten
138+
#- cargo web test --target wasm32-unknown-emscripten
139+
#- cargo web test --nodejs --target wasm32-unknown-emscripten
140+
- cargo build --target wasm32-unknown-unknown # without any features
141+
- cargo web test --nodejs --target wasm32-unknown-unknown --features=stdweb
142+
- cargo build --target wasm32-unknown-unknown --features=wasm-bindgen
65143

66144
- rust: nightly
145+
env: DESCRIPTION="cross-platform builder (doesn't run tests)"
67146
install:
68-
- rustup target add thumbv6m-none-eabi
147+
- rustup target add x86_64-sun-solaris
148+
- rustup target add x86_64-unknown-cloudabi
149+
- rustup target add x86_64-unknown-freebsd
150+
#- rustup target add x86_64-unknown-fuchsia
151+
- rustup target add x86_64-unknown-netbsd
152+
- rustup target add x86_64-unknown-redox
69153
script:
70-
# Bare metal target; no std; only works on nightly
71-
- cargo build --no-default-features --target thumbv6m-none-eabi --release
154+
- cargo build --target=x86_64-sun-solaris --all-features
155+
- cargo build --target=x86_64-unknown-cloudabi --all-features
156+
- cargo build --target=x86_64-unknown-freebsd --all-features
157+
#- cargo build --target=x86_64-unknown-fuchsia --all-features
158+
- cargo build --target=x86_64-unknown-netbsd --all-features
159+
- cargo build --target=x86_64-unknown-redox --all-features
72160

73161
# Trust cross-built/emulated targets. We must repeat all non-default values.
74162
- rust: stable
75163
sudo: required
76164
dist: trusty
77165
services: docker
78-
env: TARGET=x86_64-unknown-freebsd DISABLE_TESTS=1
166+
env: DESCRIPTION="Linux (MIPS, big-endian)" TARGET=mips-unknown-linux-gnu
79167
- rust: stable
80168
sudo: required
81169
dist: trusty
82170
services: docker
83-
env: TARGET=mips-unknown-linux-gnu
84-
- rust: stable
85-
sudo: required
86-
dist: trusty
87-
services: docker
88-
env: TARGET=armv7-linux-androideabi DISABLE_TESTS=1
89-
- rust: stable
90-
os: osx
91-
sudo: required
92-
dist: trusty
93-
services: docker
94-
env: TARGET=armv7-apple-ios DISABLE_TESTS=1
171+
env: DESCRIPTION="Android (ARMv7)" TARGET=armv7-linux-androideabi
95172

96173
before_install:
97174
- set -e

CHANGELOG.md

Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,29 @@ A [separate changelog is kept for rand_core](rand_core/CHANGELOG.md).
88

99
You may also find the [Update Guide](UPDATING.md) useful.
1010

11+
## [0.6.0] - Unreleased
12+
13+
### Crate features and organisation
14+
- The ISAAC and Xorshift RNGs have been moved to their own crates: `rand_isaac`
15+
and `rand_xorshift`. (#551, #557)
16+
- `Uniform` supports inclusive ranges: `Uniform::from(a..=b)`. This is
17+
automatically enabled for Rust >= 1.27. (#566)
18+
- Support for `i128` and `u128` is automatically enabled for Rust >= 1.26. This
19+
renders the `i128_support` feature obsolete. It still exists for backwards
20+
compatibility but does not have any effect. This breaks programs using Rand
21+
with `i128_support` on nightlies older than Rust 1.26. (#571)
22+
23+
### New distributions
24+
- Added sampling from the unit sphere and circle. (#567)
25+
26+
### Sequences module
27+
- Optimised and changed return type of the `sample_indices` function. (#479)
28+
- Added weighted sampling. (#518)
29+
30+
### Platform support
31+
- Added support for wasm-bindgen. (#541)
32+
- Added basic SIMD support. (#523)
33+
1134
## [0.5.4] - 2018-07-11
1235
### Platform support
1336
- Make `OsRng` work via WASM/stdweb for WebWorkers

Cargo.toml

Lines changed: 12 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -12,31 +12,31 @@ Random number generators and other randomness functionality.
1212
"""
1313
keywords = ["random", "rng"]
1414
categories = ["algorithms", "no-std"]
15+
build = "build.rs"
1516

1617
[badges]
1718
travis-ci = { repository = "rust-lang-nursery/rand" }
1819
appveyor = { repository = "alexcrichton/rand" }
1920

2021
[features]
2122
default = ["std" ] # without "std" rand uses libcore
22-
nightly = ["i128_support", "simd_support"] # enables all features requiring nightly rust
23+
nightly = ["simd_support"] # enables all features requiring nightly rust
2324
std = ["rand_core/std", "alloc", "libc", "winapi", "cloudabi", "fuchsia-zircon"]
2425
alloc = ["rand_core/alloc"] # enables Vec and Box support (without std)
2526
i128_support = [] # enables i128 and u128 support
2627
simd_support = ["packed_simd"] # enables SIMD support
27-
serde1 = ["serde", "serde_derive", "rand_core/serde1"] # enables serialization for PRNGs
28+
serde1 = ["rand_core/serde1", "rand_isaac/serde1", "rand_xorshift/serde1"] # enables serialization for PRNGs
2829

2930
[workspace]
30-
members = ["rand_core", "rand_isaac"]
31+
members = ["rand_core", "rand_isaac", "rand_xorshift"]
3132

3233
[dependencies]
3334
rand_core = { path = "rand_core", version = "0.2", default-features = false }
3435
# only for deprecations and benches:
35-
rand_isaac = { path = "rand_isaac", version = "0.1", default-features = false }
36+
rand_isaac = { path = "rand_isaac", version = "0.1" }
37+
rand_xorshift = { path = "rand_xorshift", version = "0.1" }
3638
log = { version = "0.4", optional = true }
3739
packed_simd = { version = "0.1", optional = true, features = ["into_bits"] }
38-
serde = { version = "1", optional = true }
39-
serde_derive = { version = "1", optional = true }
4040

4141
[target.'cfg(unix)'.dependencies]
4242
libc = { version = "0.2", optional = true }
@@ -53,12 +53,14 @@ fuchsia-zircon = { version = "0.3.2", optional = true }
5353
[target.wasm32-unknown-unknown.dependencies]
5454
# use with `--target wasm32-unknown-unknown --features=stdweb`
5555
stdweb = { version = "0.4", optional = true }
56-
wasm-bindgen = { version = "0.2", optional = true }
56+
wasm-bindgen = { version = "0.2.12", optional = true }
5757

5858
[dev-dependencies]
59-
# This is for testing serde, unfortunately we can't specify feature-gated dev
60-
# deps yet, see: https://github.com/rust-lang/cargo/issues/1596
61-
bincode = "1.0"
59+
# This has a histogram implementation used for testing uniformity.
60+
average = "0.9.2"
61+
62+
[build-dependencies]
63+
rustc_version = "0.2"
6264

6365
[package.metadata.docs.rs]
6466
all-features = true

README.md

Lines changed: 7 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -16,9 +16,11 @@ The core random number generation traits of Rand live in the [rand_core](
1616
https://crates.io/crates/rand_core) crate; this crate is most useful when
1717
implementing RNGs.
1818

19-
API reference:
20-
[master branch](https://rust-lang-nursery.github.io/rand/rand/index.html),
21-
[by release](https://docs.rs/rand/0.5).
19+
Documentation:
20+
- [API reference for latest release](https://docs.rs/rand/0.5)
21+
- [API reference for master branch](https://rust-lang-nursery.github.io/rand/rand/index.html)
22+
- [Additional documentation (subdir)](doc/README.md)
23+
2224

2325
## Usage
2426

@@ -113,10 +115,10 @@ Rand is built with only the `std` feature enabled by default. The following
113115
optional features are available:
114116

115117
- `alloc` can be used instead of `std` to provide `Vec` and `Box`.
116-
- `i128_support` enables support for generating `u128` and `i128` values.
117118
- `log` enables some logging via the `log` crate.
118-
- `nightly` enables all unstable features (`i128_support`).
119+
- `nightly` enables all unstable features (`simd_support`).
119120
- `serde1` enables serialization for some types, via Serde version 1.
121+
- `simd_support` enables uniform sampling of SIMD types (integers and floats).
120122
- `stdweb` enables support for `OsRng` on `wasm32-unknown-unknown` via `stdweb`
121123
combined with `cargo-web`.
122124
- `wasm-bindgen` enables support for `OsRng` on `wasm32-unknown-unknown` via

appveyor.yml

Lines changed: 8 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -32,8 +32,11 @@ install:
3232
build: false
3333

3434
test_script:
35-
- cargo test --all # cannot use --all and --features together
36-
- cargo test --all --benches
37-
- cargo test --features serde1,log,nightly
38-
- cargo test --tests --no-default-features --features=alloc,serde1
39-
- cargo test --package rand_core --no-default-features --features=alloc,serde1
35+
- cargo test --lib --no-default-features --features alloc
36+
- cargo test --all-features
37+
- cargo test --benches --features=nightly
38+
- cargo test --examples
39+
- cargo test --package rand_core
40+
- cargo test --package rand_core --no-default-features --features=alloc
41+
- cargo test --package rand_isaac --features=serde1
42+
- cargo test --package rand_xorshift --features=serde1

0 commit comments

Comments
 (0)