| commit | e13be22b92e9912a2c3bd002575e6387d0717eb6 | [log] [tgz] |
|---|---|---|
| author | android-build-team Robot <[email protected]> | Fri Apr 30 01:05:49 2021 +0000 |
| committer | android-build-team Robot <[email protected]> | Fri Apr 30 01:05:49 2021 +0000 |
| tree | b6030c920777b49632dce5c4ed4a1783329c9e3a | |
| parent | de73449cefd393d3ae88dbb13e8d7ef4712506b2 [diff] | |
| parent | fda5a37ad654e3d7caec8be7b0dc2ae582552df9 [diff] |
Snap for 7325096 from fda5a37ad654e3d7caec8be7b0dc2ae582552df9 to sc-d1-release Change-Id: I0b11141bfe1c6ea50bcb884881cafea5e404b49f
Numeric traits for generic mathematics in Rust.
Add this to your Cargo.toml:
[dependencies] num-traits = "0.2"
and this to your crate root:
extern crate num_traits;
This crate can be used without the standard library (#![no_std]) by disabling the default std feature. Use this in Cargo.toml:
[dependencies.num-traits] version = "0.2" default-features = false # features = ["libm"] # <--- Uncomment if you wish to use `Float` and `Real` without `std`
The Float and Real traits are only available when either std or libm is enabled.
The libm feature is only available with Rust 1.31 and later (see PR #99).
The FloatCore trait is always available. MulAdd and MulAddAssign for f32 and f64 also require std or libm, as do implementations of signed and floating- point exponents in Pow.
Implementations for i128 and u128 are only available with Rust 1.26 and later. The build script automatically detects this, but you can make it mandatory by enabling the i128 crate feature.
Release notes are available in RELEASES.md.
The num-traits crate is tested for rustc 1.8 and greater.
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.