Index: tests/compiler/dart2js/tdiv_test.dart |
diff --git a/tests/compiler/dart2js/tdiv_test.dart b/tests/compiler/dart2js/tdiv_test.dart |
new file mode 100644 |
index 0000000000000000000000000000000000000000..86eb9557b709424a4b4ad2edb6e6dd032da9b84d |
--- /dev/null |
+++ b/tests/compiler/dart2js/tdiv_test.dart |
@@ -0,0 +1,94 @@ |
+// Copyright (c) 2015, 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. |
+ |
+library tdiv_test; |
+ |
+import 'dart:async'; |
+import 'package:expect/expect.dart'; |
+import 'package:async_helper/async_helper.dart'; |
+import 'compiler_helper.dart'; |
+ |
+const String TEST1 = r""" |
+foo(param) { |
+ var a = param ? 0xFFFFFFFF : 1; |
+ return a ~/ 2; |
+ // Above can be compiled to division followed by truncate. |
+ // present: ' / 2 | 0' |
+ // absent: 'tdiv' |
+} |
+"""; |
+ |
+const String TEST2 = r""" |
+foo(param) { |
+ var a = param ? 0xFFFFFFFF : 1; |
+ return a ~/ 3; |
+ // Above can be compiled to division followed by truncate. |
+ // present: ' / 3 | 0' |
+ // absent: 'tdiv' |
+} |
+"""; |
+ |
+const String TEST3 = r""" |
+foo(param) { |
+ var a = param ? 0xFFFFFFFF : -1; |
+ return a ~/ 2; |
+ // Potentially negative inputs go via fast helper. |
+ // present: '_tdivFast' |
+ // absent: '/' |
+} |
+"""; |
+ |
+const String TEST4 = r""" |
+foo(param1, param2) { |
+ var a = param1 ? 0xFFFFFFFF : 0; |
+ return a ~/ param2; |
+ // Unknown divisor goes via full implementation. |
+ // present: '$tdiv' |
+ // absent: '/' |
+} |
+"""; |
+ |
+const String TEST5 = r""" |
+foo(param1, param2) { |
+ var a = param1 ? 0xFFFFFFFF : 0; |
+ var b = param2 ? 3 : 4; |
+ return a ~/ param2; |
+ // We could optimize this with range analysis, but type inference summarizes |
+ // '3 or 4' to uint31, which is not >= 2. |
+ // present: '$tdiv' |
+ // absent: '/' |
+} |
+"""; |
+ |
+main() { |
+ RegExp directivePattern = new RegExp( |
+ // \1 \2 \3 |
+ r'''// *(present|absent): (?:"([^"]*)"|'([^'']*)')''', |
+ multiLine: true); |
+ |
+ Future check(String test) { |
+ return compile(test, entry: 'foo', check: (String generated) { |
+ for (Match match in directivePattern.allMatches(test)) { |
+ String directive = match.group(1); |
+ String pattern = match.groups([2, 3]).where((s) => s != null).single; |
+ if (directive == 'present') { |
+ Expect.isTrue(generated.contains(pattern), |
+ "Cannot find '$pattern' in:\n$generated"); |
+ } else { |
+ assert(directive == 'absent'); |
+ Expect.isFalse(generated.contains(pattern), |
+ "Must not find '$pattern' in:\n$generated"); |
+ } |
+ } |
+ }); |
+ } |
+ |
+ asyncTest(() => Future.wait([ |
+ check(TEST1), |
+ check(TEST2), |
+ check(TEST3), |
+ check(TEST4), |
+ check(TEST5), |
+ ])); |
+} |