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

Unified Diff: tests/language/bailout4_test.dart

Issue 11411068: Fix bad assumption of environment builder when it comes to nested loops: blocks inside a loop would… (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 8 years, 1 month 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/language/bailout4_test.dart
===================================================================
--- tests/language/bailout4_test.dart (revision 0)
+++ tests/language/bailout4_test.dart (revision 0)
@@ -0,0 +1,30 @@
+// Copyright (c) 2012, 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 that dart2s computes the right bailout environment in presence
+// of nested loops.
+
+class A {
+ operator[] (index) => 42;
+}
+
+var a = new A();
+var b = new List(4);
+int count = 0;
+
+main() {
+ // Make the method recursive to make sure it gets an optimized
+ // version.
+ if (b[0] != null) main();
+
+ for (int i = 0; i < 2; i++) {
+ for (int j = 0; j < 2; j++) {
+ for (int k = 0; k < 2; k++) {
+ Expect.equals(42, a[i + j + k]);
+ count++;
+ }
+ }
+ }
+ Expect.equals(8, count);
+}

Powered by Google App Engine
This is Rietveld 408576698