2021-12-06 12:33:31 +01:00
|
|
|
#![feature(const_fn_floating_point_arithmetic)]
|
2020-02-23 00:04:11 -08:00
|
|
|
#![warn(clippy::suboptimal_flops)]
|
|
|
|
|
2021-12-06 12:33:31 +01:00
|
|
|
/// Allow suboptimal_ops in constant context
|
|
|
|
pub const fn in_const_context() {
|
|
|
|
let a: f64 = 1234.567;
|
|
|
|
let b: f64 = 45.67834;
|
|
|
|
let c: f64 = 0.0004;
|
|
|
|
|
|
|
|
let _ = a * b + c;
|
|
|
|
let _ = c + a * b;
|
|
|
|
}
|
|
|
|
|
2020-02-23 00:04:11 -08:00
|
|
|
fn main() {
|
|
|
|
let a: f64 = 1234.567;
|
|
|
|
let b: f64 = 45.67834;
|
|
|
|
let c: f64 = 0.0004;
|
|
|
|
let d: f64 = 0.0001;
|
|
|
|
|
|
|
|
let _ = a * b + c;
|
2022-10-06 09:44:38 +02:00
|
|
|
let _ = a * b - c;
|
2020-02-23 00:04:11 -08:00
|
|
|
let _ = c + a * b;
|
2022-10-06 09:44:38 +02:00
|
|
|
let _ = c - a * b;
|
2020-02-23 00:04:11 -08:00
|
|
|
let _ = a + 2.0 * 4.0;
|
|
|
|
let _ = a + 2. * 4.;
|
|
|
|
|
|
|
|
let _ = (a * b) + c;
|
|
|
|
let _ = c + (a * b);
|
|
|
|
let _ = a * b * c + d;
|
|
|
|
|
|
|
|
let _ = a.mul_add(b, c) * a.mul_add(b, c) + a.mul_add(b, c) + c;
|
|
|
|
let _ = 1234.567_f64 * 45.67834_f64 + 0.0004_f64;
|
2020-07-14 14:59:59 +02:00
|
|
|
|
|
|
|
let _ = (a * a + b).sqrt();
|
|
|
|
|
2023-11-02 17:35:56 +01:00
|
|
|
let u = 1usize;
|
|
|
|
let _ = a - (b * u as f64);
|
|
|
|
|
2020-07-14 14:59:59 +02:00
|
|
|
// Cases where the lint shouldn't be applied
|
|
|
|
let _ = (a * a + b * b).sqrt();
|
2020-02-23 00:04:11 -08:00
|
|
|
}
|
2023-12-01 18:21:58 +01:00
|
|
|
|
|
|
|
fn _issue11831() {
|
|
|
|
struct NotAFloat;
|
|
|
|
|
|
|
|
impl std::ops::Add<f64> for NotAFloat {
|
|
|
|
type Output = Self;
|
|
|
|
|
|
|
|
fn add(self, _: f64) -> Self {
|
|
|
|
NotAFloat
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
let a = NotAFloat;
|
|
|
|
let b = 1.0_f64;
|
|
|
|
let c = 1.0;
|
|
|
|
|
|
|
|
let _ = a + b * c;
|
|
|
|
}
|