pub fn modff(x: f32) -> (f32, f32) { | |
let rv2: f32; | |
let mut u: u32 = x.to_bits(); | |
let mask: u32; | |
let e = ((u >> 23 & 0xff) as i32) - 0x7f; | |
/* no fractional part */ | |
if e >= 23 { | |
rv2 = x; | |
if e == 0x80 && (u << 9) != 0 { | |
/* nan */ | |
return (x, rv2); | |
} | |
u &= 0x80000000; | |
return (f32::from_bits(u), rv2); | |
} | |
/* no integral part */ | |
if e < 0 { | |
u &= 0x80000000; | |
rv2 = f32::from_bits(u); | |
return (x, rv2); | |
} | |
mask = 0x007fffff >> e; | |
if (u & mask) == 0 { | |
rv2 = x; | |
u &= 0x80000000; | |
return (f32::from_bits(u), rv2); | |
} | |
u &= !mask; | |
rv2 = f32::from_bits(u); | |
return (x - rv2, rv2); | |
} |