var xs = [ // Definitely heap digits. -(2n ** 1000n), // -(2n**64n) -18446744073709551617n, -18446744073709551616n, -18446744073709551615n, // -(2n**63n) -9223372036854775809n, -9223372036854775808n, -9223372036854775807n, // -(2**32) -4294967297n, -4294967296n, -4294967295n, // -(2**31) -2147483649n, -2147483648n, -2147483647n, -1n, 0n, 1n, // 2**31 2147483647n, 2147483648n, 2147483649n, // 2**32 4294967295n, 4294967296n, 4294967297n, // 2n**63n 9223372036854775807n, 9223372036854775808n, 9223372036854775809n, // 2n**64n 18446744073709551615n, 18446744073709551616n, 18446744073709551617n, // Definitely heap digits. 2n ** 1000n, ]; function testNeg() { for (var i = 0; i < 100; ++i) { var j = i % xs.length; var x = xs[j]; var y = xs[xs.length - 1 - j]; assertEq(-x, y); } } testNeg(); function testBitNot() { var ys = xs.map(x => -(x + 1n)); for (var i = 0; i < 100; ++i) { var j = i % xs.length; var x = xs[j]; var y = ys[j]; assertEq(~x, y); } } testBitNot(); function testPreInc() { var ys = xs.map(x => x + 1n); for (var i = 0; i < 100; ++i) { var j = i % xs.length; var x = xs[j]; var y = ys[j]; var r = ++x; assertEq(x, y); assertEq(r, y); } } testPostInc(); function testPostInc() { var ys = xs.map(x => x + 1n); for (var i = 0; i < 100; ++i) { var j = i % xs.length; var x = xs[j]; var y = ys[j]; var r = x++; assertEq(x, y); assertEq(r, xs[j]); } } testPostInc(); function testPreDec() { var ys = xs.map(x => x - 1n); for (var i = 0; i < 100; ++i) { var j = i % xs.length; var x = xs[j]; var y = ys[j]; var r = --x; assertEq(x, y); assertEq(r, y); } } testPostDec(); function testPostDec() { var ys = xs.map(x => x - 1n); for (var i = 0; i < 100; ++i) { var j = i % xs.length; var x = xs[j]; var y = ys[j]; var r = x--; assertEq(x, y); assertEq(r, xs[j]); } } testPostDec();