2023-07-27 06:40:22 -05:00
|
|
|
#![warn(clippy::transmute_float_to_int)]
|
2024-02-19 07:53:53 -06:00
|
|
|
#![allow(clippy::missing_transmute_annotations)]
|
2023-07-27 06:40:22 -05:00
|
|
|
|
|
|
|
fn float_to_int() {
|
|
|
|
let _: u32 = unsafe { 1f32.to_bits() };
|
2023-07-28 14:35:48 -05:00
|
|
|
//~^ ERROR: transmute from a `f32` to a `u32`
|
|
|
|
//~| NOTE: `-D clippy::transmute-float-to-int` implied by `-D warnings`
|
2023-07-27 06:40:22 -05:00
|
|
|
let _: i32 = unsafe { 1f32.to_bits() as i32 };
|
2023-07-28 14:35:48 -05:00
|
|
|
//~^ ERROR: transmute from a `f32` to a `i32`
|
2023-07-27 06:40:22 -05:00
|
|
|
let _: u64 = unsafe { 1f64.to_bits() };
|
2023-07-28 14:35:48 -05:00
|
|
|
//~^ ERROR: transmute from a `f64` to a `u64`
|
2023-07-27 06:40:22 -05:00
|
|
|
let _: i64 = unsafe { 1f64.to_bits() as i64 };
|
2023-07-28 14:35:48 -05:00
|
|
|
//~^ ERROR: transmute from a `f64` to a `i64`
|
2023-07-27 06:40:22 -05:00
|
|
|
let _: u64 = unsafe { 1.0f64.to_bits() };
|
2023-07-28 14:35:48 -05:00
|
|
|
//~^ ERROR: transmute from a `f64` to a `u64`
|
2023-07-27 06:40:22 -05:00
|
|
|
let _: u64 = unsafe { (-1.0f64).to_bits() };
|
2023-07-28 14:35:48 -05:00
|
|
|
//~^ ERROR: transmute from a `f64` to a `u64`
|
2023-07-27 06:40:22 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
mod issue_5747 {
|
|
|
|
const VALUE32: i32 = unsafe { std::mem::transmute(1f32) };
|
|
|
|
const VALUE64: u64 = unsafe { std::mem::transmute(1f64) };
|
|
|
|
|
|
|
|
const fn to_bits_32(v: f32) -> u32 {
|
|
|
|
unsafe { std::mem::transmute(v) }
|
|
|
|
}
|
|
|
|
|
|
|
|
const fn to_bits_64(v: f64) -> i64 {
|
|
|
|
unsafe { std::mem::transmute(v) }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {}
|