zig/std/special/compiler_rt/fixunssfdi_test.zig
Andrew Kelley 6a98bf3dba compiler_rt implementations for __fixuns* functions
* add u128 and i128 integer types
 * add f128 floating point type
 * implement big integer multiplication (See #405)
2017-08-16 19:07:35 -04:00

36 lines
1.0 KiB
Zig

const __fixunssfdi = @import("fixunssfdi.zig").__fixunssfdi;
const assert = @import("../../debug.zig").assert;
fn test__fixunssfdi(a: f32, expected: u64) {
const x = __fixunssfdi(a);
assert(x == expected);
}
test "fixunssfdi" {
test__fixunssfdi(0.0, 0);
test__fixunssfdi(0.5, 0);
test__fixunssfdi(0.99, 0);
test__fixunssfdi(1.0, 1);
test__fixunssfdi(1.5, 1);
test__fixunssfdi(1.99, 1);
test__fixunssfdi(2.0, 2);
test__fixunssfdi(2.01, 2);
test__fixunssfdi(-0.5, 0);
test__fixunssfdi(-0.99, 0);
test__fixunssfdi(-1.0, 0);
test__fixunssfdi(-1.5, 0);
test__fixunssfdi(-1.99, 0);
test__fixunssfdi(-2.0, 0);
test__fixunssfdi(-2.01, 0);
test__fixunssfdi(0x1.FFFFFEp+63, 0xFFFFFF0000000000);
test__fixunssfdi(0x1.000000p+63, 0x8000000000000000);
test__fixunssfdi(0x1.FFFFFEp+62, 0x7FFFFF8000000000);
test__fixunssfdi(0x1.FFFFFCp+62, 0x7FFFFF0000000000);
test__fixunssfdi(-0x1.FFFFFEp+62, 0x0000000000000000);
test__fixunssfdi(-0x1.FFFFFCp+62, 0x0000000000000000);
}