Skip to content

Commit

Permalink
Bump MSRV to 1.60
Browse files Browse the repository at this point in the history
  • Loading branch information
cuviper committed May 8, 2024
1 parent e9c5ac8 commit 8c18cab
Show file tree
Hide file tree
Showing 8 changed files with 30 additions and 52 deletions.
25 changes: 4 additions & 21 deletions .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,7 @@ jobs:
strategy:
matrix:
rust: [
1.31.0, # 2018!
1.36.0, # alloc, rand
1.60.0, # MSRV
stable,
beta,
nightly
Expand All @@ -29,8 +28,8 @@ jobs:
- run: ./ci/test_full.sh

# try a target that doesn't have std at all, but does have alloc
no_std_stable:
name: No Std (stable)
no_std:
name: No Std
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
Expand All @@ -39,22 +38,6 @@ jobs:
target: thumbv6m-none-eabi
- run: cargo build --target thumbv6m-none-eabi --no-default-features --features "alloc libm serde rand"

# try a target that doesn't have std at all, nor alloc
no_std_131:
name: No Std (1.31.0)
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/cache@v4
with:
path: ~/.cargo/registry/index
key: cargo-1.31.0-git-index
- uses: dtolnay/rust-toolchain@1.31.0
with:
target: thumbv6m-none-eabi
- run: cargo generate-lockfile && cargo update -p libm --precise 0.2.5
- run: cargo build --target thumbv6m-none-eabi --no-default-features --features "libm"

fmt:
name: Format
runs-on: ubuntu-latest
Expand All @@ -70,7 +53,7 @@ jobs:
success:
name: Success
runs-on: ubuntu-latest
needs: [test, no_std_131, no_std_stable, fmt]
needs: [test, no_std, fmt]
# Github branch protection is exceedingly silly and treats "jobs skipped because a dependency
# failed" as success. So we have to do some contortions to ensure the job fails if any of its
# dependencies fails.
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/master.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ jobs:
runs-on: ubuntu-latest
strategy:
matrix:
rust: [1.31.0, stable]
rust: [1.60.0, stable]
steps:
- uses: actions/checkout@v4
- uses: actions/cache@v4
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/pr.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ jobs:
runs-on: ubuntu-latest
strategy:
matrix:
rust: [1.31.0, stable]
rust: [1.60.0, stable]
steps:
- uses: actions/checkout@v4
- uses: actions/cache@v4
Expand Down
7 changes: 5 additions & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ version = "0.4.2"
readme = "README.md"
exclude = ["/ci/*", "/.github/*"]
edition = "2018"
rust-version = "1.60"

[package.metadata.docs.rs]
features = ["std", "serde", "rand"]
Expand Down Expand Up @@ -54,16 +55,18 @@ features = ["i128"]
[features]
default = ["std"]

num-bigint = ["dep:num-bigint"]

std = [
"num-bigint/std",
"dep:num-bigint", "num-bigint/std",
"num-complex/std",
"num-integer/std",
"num-iter/std",
"num-rational/std", "num-rational/num-bigint-std",
"num-traits/std",
]

alloc = ["num-bigint", "num-rational/num-bigint"]
alloc = ["dep:num-bigint", "num-rational/num-bigint"]

libm = [
"num-complex/libm",
Expand Down
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

[![crate](https://img.shields.io/crates/v/num.svg)](https://crates.io/crates/num)
[![documentation](https://docs.rs/num/badge.svg)](https://docs.rs/num)
[![minimum rustc 1.31](https://img.shields.io/badge/rustc-1.31+-red.svg)](https://rust-lang.github.io/rfcs/2495-min-rust-version.html)
[![minimum rustc 1.60](https://img.shields.io/badge/rustc-1.60+-red.svg)](https://rust-lang.github.io/rfcs/2495-min-rust-version.html)
[![build status](https://github.com/rust-num/num/workflows/master/badge.svg)](https://github.com/rust-num/num/actions)

A collection of numeric types and traits for Rust.
Expand Down Expand Up @@ -69,7 +69,7 @@ Release notes are available in [RELEASES.md](RELEASES.md).

## Compatibility

The `num` crate as a whole is tested for rustc 1.31 and greater.
The `num` crate as a whole is tested for rustc 1.60 and greater.

The `num-traits`, `num-integer`, and `num-iter` crates are individually tested
for rustc 1.8 and greater, if you require such older compatibility.
Expand Down
2 changes: 1 addition & 1 deletion ci/rustup.sh
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,6 @@
set -ex

ci=$(dirname $0)
for version in 1.31.0 1.36.0 stable beta nightly; do
for version in 1.60.0 stable beta nightly; do
rustup run "$version" "$ci/test_full.sh"
done
38 changes: 15 additions & 23 deletions ci/test_full.sh
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
set -e

CRATE=num
MSRV=1.31
MSRV=1.60

get_rust_version() {
local array=($(rustc --version));
Expand All @@ -27,21 +27,15 @@ if ! check_version $MSRV ; then
exit 1
fi

STD_FEATURES=(libm serde)
STD_FEATURES=(libm serde rand)
ALLOC_FEATURES=(libm serde rand)
NO_STD_FEATURES=(libm)
check_version 1.36 && STD_FEATURES+=(rand)
check_version 1.36 && ALLOC_FEATURES=(libm serde rand)
echo "Testing supported features: ${STD_FEATURES[*]}"
echo " alloc supported features: ${ALLOC_FEATURES[*]}"
echo " no_std supported features: ${NO_STD_FEATURES[*]}"
if [ -n "${ALLOC_FEATURES[*]}" ]; then
echo " alloc supported features: ${ALLOC_FEATURES[*]}"
fi

cargo generate-lockfile

# libm 0.2.6 started using {float}::EPSILON
check_version 1.43 || cargo update -p libm --precise 0.2.5

set -x

# test the default with std
Expand Down Expand Up @@ -74,18 +68,16 @@ cargo build --no-default-features --features="${NO_STD_FEATURES[*]}"
cargo test --no-default-features --features="${NO_STD_FEATURES[*]}"


if [ -n "${ALLOC_FEATURES[*]}" ]; then
# test minimal with alloc
cargo build --no-default-features --features="alloc"
cargo test --no-default-features --features="alloc"
# test minimal with alloc
cargo build --no-default-features --features="alloc"
cargo test --no-default-features --features="alloc"

# test each isolated feature with alloc
for feature in ${ALLOC_FEATURES[*]}; do
cargo build --no-default-features --features="alloc $feature"
cargo test --no-default-features --features="alloc $feature"
done
# test each isolated feature with alloc
for feature in ${ALLOC_FEATURES[*]}; do
cargo build --no-default-features --features="alloc $feature"
cargo test --no-default-features --features="alloc $feature"
done

# test all supported features with alloc
cargo build --no-default-features --features="alloc ${ALLOC_FEATURES[*]}"
cargo test --no-default-features --features="alloc ${ALLOC_FEATURES[*]}"
fi
# test all supported features with alloc
cargo build --no-default-features --features="alloc ${ALLOC_FEATURES[*]}"
cargo test --no-default-features --features="alloc ${ALLOC_FEATURES[*]}"
2 changes: 1 addition & 1 deletion src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@
//!
//! ## Compatibility
//!
//! The `num` crate is tested for rustc 1.31 and greater.
//! The `num` crate is tested for rustc 1.60 and greater.
#![doc(html_root_url = "https://docs.rs/num/0.4")]
#![no_std]
Expand Down

0 comments on commit 8c18cab

Please sign in to comment.