//@run-rustfix #![feature(const_fn_floating_point_arithmetic)] #![warn(clippy::suboptimal_flops)] /// Allow suboptimal_flops in constant context pub const fn const_context() { let x = 3f32; let _ = x * 180f32 / std::f32::consts::PI; } pub fn issue9391(degrees: i64) { let _ = (degrees as f64).to_radians(); let _ = (degrees as f64).to_degrees(); } fn main() { let x = 3f32; let _ = x.to_degrees(); let _ = 90.0_f64.to_degrees(); let _ = 90.5_f64.to_degrees(); let _ = x.to_radians(); let _ = 90.0_f64.to_radians(); let _ = 90.5_f64.to_radians(); // let _ = 90.5 * 80. * std::f32::consts::PI / 180f32; // Cases where the lint shouldn't be applied let _ = x * 90f32 / std::f32::consts::PI; let _ = x * std::f32::consts::PI / 90f32; let _ = x * 180f32 / std::f32::consts::E; let _ = x * std::f32::consts::E / 180f32; }