Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(553)

Unified Diff: tests/compiler/dart2js_extra/26243_test.dart

Issue 1914623002: Fix for issue 26243 - illegal motion of assignments in instruction merging (Closed) Base URL: https://github.com/dart-lang/sdk.git@master
Patch Set: Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: tests/compiler/dart2js_extra/26243_test.dart
diff --git a/tests/compiler/dart2js_extra/26243_test.dart b/tests/compiler/dart2js_extra/26243_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..9dc92c680ee3d4d027b98422d309afc2c8ec563a
--- /dev/null
+++ b/tests/compiler/dart2js_extra/26243_test.dart
@@ -0,0 +1,37 @@
+import 'package:expect/expect.dart';
+
+var trace = [];
+void write(String s, int a, int b) {
+ trace.add("$s $a $b");
+}
+
+void foo() {
+ var i = 0;
+ write("foo", i, i += 1);
+}
+
+
+void bar() {
+ var i = 0;
+ try {
+ write("bar", i, i += 1);
+ } catch (_) {}
+}
+
+void baz() {
+ var i = 0;
+ write("baz-notry", i, i += 1);
+
+ i = 0;
+ try {
+ write("baz-try", i, i += 1);
+ } catch (_) {}
+}
+
+void main() {
+ foo();
+ bar();
+ baz();
+ Expect.listEquals(['foo 0 1', 'bar 0 1', 'baz-notry 0 1', 'baz-try 0 1'],
+ trace);
+}

Powered by Google App Engine
This is Rietveld 408576698