| Index: tests/standalone/unboxed_int_converter_test.dart
|
| diff --git a/tests/standalone/unboxed_int_converter_test.dart b/tests/standalone/unboxed_int_converter_test.dart
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..2b75a01be58ed503ef63e65caa0e08ace01d6068
|
| --- /dev/null
|
| +++ b/tests/standalone/unboxed_int_converter_test.dart
|
| @@ -0,0 +1,79 @@
|
| +// Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file
|
| +// for details. All rights reserved. Use of this source code is governed by a
|
| +// BSD-style license that can be found in the LICENSE file.
|
| +// Test UnboxedIntConverter for int32.
|
| +// VMOptions=--optimization-counter-threshold=10 --no-use-osr
|
| +
|
| +import "package:expect/expect.dart";
|
| +import "dart:typed_data";
|
| +
|
| +int32_add(a, b, c) => (a * c) + (b * c);
|
| +int32_mul(a, b, c) => (a * c) * b;
|
| +int32_sub(a, b, c) => (a * c) - (b * c);
|
| +int32_shr(a, b, c) => (a * c * b) >> 16;
|
| +int32_shl(a, b, c) => (a * c * b) << 16;
|
| +int32_xor(a, b, c) => (a * c) ^ (b * c);
|
| +int32_or(a, b, c) => (a * c) | (b * c);
|
| +int32_and(a, b, c) => (a * c) & (b * c);
|
| +
|
| +int32_to_mint(a, b) {
|
| + var sum = 0;
|
| + var j = 0;
|
| + for (var i = a; i <= b; i++) {
|
| + sum -= (j * ++j) & 0xff;
|
| + }
|
| +
|
| + return 0xffffffff + sum;
|
| +}
|
| +
|
| +mint_to_int32(a, c, d) {
|
| + return a * a * a * (c - d);
|
| +}
|
| +
|
| +uint32_to_int32(a, c) {
|
| + return (a * a * a) * (c & 0xFFFFFFFF);
|
| +
|
| +}
|
| +
|
| +main() {
|
| + for (var j = 0; j < 1000; j++) {
|
| + Expect.equals(2, int32_add(1, 1, 1));
|
| + Expect.equals(1, int32_mul(1, 1, 1));
|
| + Expect.equals(0, int32_sub(1, 1, 1));
|
| + Expect.equals(0, int32_shr(1, 1, 1));
|
| + Expect.equals(1 << 16, int32_shl(1, 1, 1));
|
| + Expect.equals(0, int32_xor(1, 1, 1));
|
| + Expect.equals(1, int32_or(1, 1, 1));
|
| + Expect.equals(1, int32_and(1, 1, 1));
|
| + }
|
| +
|
| + Expect.equals(0x7ffffffe, int32_add(0x7ffffffc ~/ 2, 1, 2));
|
| + Expect.equals(-0x80000000, int32_add(-0x7ffffffe ~/ 2, -1, 2));
|
| + Expect.equals(-0x80000002, int32_add(-0x7ffffffe ~/ 2, -2, 2)); // Overflow.
|
| + Expect.equals(0x7ffffffe, int32_sub(0x7ffffffc ~/ 2, -1, 2));
|
| + Expect.equals(-0x80000000, int32_sub(-0x7ffffffe ~/ 2, 1, 2));
|
| + Expect.equals(-0x80000002, int32_sub(-0x7ffffffe ~/ 2, 2, 2)); // Overflow.
|
| + Expect.equals(-0x7ffffffe, int32_mul(0x7ffffffe ~/ 2, -1, 2));
|
| + Expect.equals(-0x80000000, int32_mul(-0x80000000 ~/ 2, 1, 2));
|
| + Expect.equals(0x80000000, int32_mul(-0x80000000 ~/ 2, -1, 2)); // Overflow.
|
| + Expect.equals(0x60000000, int32_xor(0x40000000 ~/ 2, 0x20000000 ~/ 2, 2));
|
| + Expect.equals(0x00000000, int32_xor(0x40000000 ~/ 2, 0x40000000 ~/ 2, 2));
|
| + Expect.equals(0x60000000, int32_or(0x40000000 ~/ 2, 0x20000000 ~/ 2, 2));
|
| + Expect.equals(0x60000000, int32_or(0x60000000 ~/ 2, 0x40000000 ~/ 2, 2));
|
| + Expect.equals(0x00000000, int32_and(0x40000000 ~/ 2, 0x20000000 ~/ 2, 2));
|
| + Expect.equals(0x40000000, int32_and(0x60000000 ~/ 2, 0x40000000 ~/ 2, 2));
|
| + Expect.equals(1, int32_shr(1, 1 << 16, 1));
|
| + Expect.equals(-1 << 15, int32_shr(1 << 15, -(1 << 16), 1));
|
| + Expect.equals(-0x080000000, int32_shl(-1 << 15, 1, 1));
|
| + Expect.equals(-0x100000000, int32_shl(-1 << 16, 1, 1)); // Overflow.
|
| +
|
| + Expect.equals(0, int32_shr(1, 1, 1));
|
| + Expect.equals(1 << 16, int32_shl(1, 1, 1));
|
| +
|
| + for (var j = 0; j < 1000; j++) {
|
| + Expect.equals(4294839503, int32_to_mint(0, 1000));
|
| + Expect.equals(-8, mint_to_int32(2, 0x100000000, 0x100000001));
|
| + Expect.equals(8, uint32_to_int32(2, 0x100000001));
|
| + }
|
| + Expect.equals(8 * 0x80000001, uint32_to_int32(2, 0x180000001));
|
| +}
|
|
|