blob: f6b0cc39952f67d3b21ebf23977834aefe3d0429 [file] [log] [blame]
// Copyright (c) 2013, 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.
// Dart test optimization of modulo operator on Smi.
// VMOptions=--optimization-counter-threshold=10 --no-use-osr
import "package:expect/expect.dart";
main() {
for (int i = -30; i < 30; i++) {
Expect.equals(i % 9, foo(i, 9));
// Zero test is done outside the loop.
if (i < 0) {
Expect.equals(i ~/ -i, foo2(i));
} else if (i > 0) {
Expect.equals(i ~/ i, foo2(i));
}
}
Expect.throws(() => foo(12, 0), (e) => e is IntegerDivisionByZeroException);
Expect.throws(() => foo2(0), (e) => e is IntegerDivisionByZeroException);
}
foo(i, x) => i % x;
foo2(i) {
// Make sure x has a range computed.
var x = 0;
if (i < 0) {
x = -i;
} else {
x = i;
}
return i ~/ x;
}