Source code

Revision control

Copy as Markdown

Other Tools

// asIntN test specialised when the input is an Int32 value.
const tests = [
[-0x80000000n, 0, 0n],
[-0x7fffffffn, 0, 0n],
[-0x7ffffffen, 0, 0n],
[-9n, 0, 0n],
[-8n, 0, 0n],
[-7n, 0, 0n],
[-6n, 0, 0n],
[-5n, 0, 0n],
[-4n, 0, 0n],
[-3n, 0, 0n],
[-2n, 0, 0n],
[-1n, 0, 0n],
[0n, 0, 0n],
[1n, 0, 0n],
[2n, 0, 0n],
[3n, 0, 0n],
[4n, 0, 0n],
[5n, 0, 0n],
[6n, 0, 0n],
[7n, 0, 0n],
[8n, 0, 0n],
[9n, 0, 0n],
[0x7ffffffen, 0, 0n],
[0x7fffffffn, 0, 0n],
[-0x80000000n, 1, 0n],
[-0x7fffffffn, 1, -1n],
[-0x7ffffffen, 1, 0n],
[-9n, 1, -1n],
[-8n, 1, 0n],
[-7n, 1, -1n],
[-6n, 1, 0n],
[-5n, 1, -1n],
[-4n, 1, 0n],
[-3n, 1, -1n],
[-2n, 1, 0n],
[-1n, 1, -1n],
[0n, 1, 0n],
[1n, 1, -1n],
[2n, 1, 0n],
[3n, 1, -1n],
[4n, 1, 0n],
[5n, 1, -1n],
[6n, 1, 0n],
[7n, 1, -1n],
[8n, 1, 0n],
[9n, 1, -1n],
[0x7ffffffen, 1, 0n],
[0x7fffffffn, 1, -1n],
[-0x80000000n, 2, 0n],
[-0x7fffffffn, 2, 1n],
[-0x7ffffffen, 2, -2n],
[-9n, 2, -1n],
[-8n, 2, 0n],
[-7n, 2, 1n],
[-6n, 2, -2n],
[-5n, 2, -1n],
[-4n, 2, 0n],
[-3n, 2, 1n],
[-2n, 2, -2n],
[-1n, 2, -1n],
[0n, 2, 0n],
[1n, 2, 1n],
[2n, 2, -2n],
[3n, 2, -1n],
[4n, 2, 0n],
[5n, 2, 1n],
[6n, 2, -2n],
[7n, 2, -1n],
[8n, 2, 0n],
[9n, 2, 1n],
[0x7ffffffen, 2, -2n],
[0x7fffffffn, 2, -1n],
[-0x80000000n, 31, 0n],
[-0x7fffffffn, 31, 1n],
[-0x7ffffffen, 31, 2n],
[-9n, 31, -9n],
[-8n, 31, -8n],
[-7n, 31, -7n],
[-6n, 31, -6n],
[-5n, 31, -5n],
[-4n, 31, -4n],
[-3n, 31, -3n],
[-2n, 31, -2n],
[-1n, 31, -1n],
[0n, 31, 0n],
[1n, 31, 1n],
[2n, 31, 2n],
[3n, 31, 3n],
[4n, 31, 4n],
[5n, 31, 5n],
[6n, 31, 6n],
[7n, 31, 7n],
[8n, 31, 8n],
[9n, 31, 9n],
[0x7ffffffen, 31, -2n],
[0x7fffffffn, 31, -1n],
[-0x80000000n, 32, -0x80000000n],
[-0x7fffffffn, 32, -0x7fffffffn],
[-0x7ffffffen, 32, -0x7ffffffen],
[-9n, 32, -9n],
[-8n, 32, -8n],
[-7n, 32, -7n],
[-6n, 32, -6n],
[-5n, 32, -5n],
[-4n, 32, -4n],
[-3n, 32, -3n],
[-2n, 32, -2n],
[-1n, 32, -1n],
[0n, 32, 0n],
[1n, 32, 1n],
[2n, 32, 2n],
[3n, 32, 3n],
[4n, 32, 4n],
[5n, 32, 5n],
[6n, 32, 6n],
[7n, 32, 7n],
[8n, 32, 8n],
[9n, 32, 9n],
[0x7ffffffen, 32, 0x7ffffffen],
[0x7fffffffn, 32, 0x7fffffffn],
];
function f(tests) {
for (let test of tests) {
let input = test[0], bits = test[1], expected = test[2];
assertEq(BigInt.asIntN(bits, input), expected);
}
}
for (let i = 0; i < 10; ++i) {
f(tests);
}