OLD | NEW |
| (Empty) |
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | |
2 // for details. All rights reserved. Use of this source code is governed by a | |
3 // BSD-style license that can be found in the LICENSE file. | |
4 // VMOptions=--optimization-counter-threshold=100 | |
5 | |
6 // Test lazy deoptimization at type checks with interface implementation. | |
7 | |
8 import "package:expect/expect.dart"; | |
9 import "cha_deopt3_lib.dart"; | |
10 import "cha_deopt3_deferred_lib.dart" deferred as d; | |
11 | |
12 var loaded = false; | |
13 | |
14 main() { | |
15 for (var i = 0; i < 2000; i++) bla(); | |
16 Expect.equals(1, bla()); | |
17 d.loadLibrary().then((_) { | |
18 loaded = true; | |
19 Expect.equals(1, bla()); | |
20 }); | |
21 } | |
22 | |
23 make_array() { | |
24 try { | |
25 if (loaded) { | |
26 return [new A(), new B(), new C(), new D(), new E(), d.make_u()]; | |
27 } else { | |
28 return [new A(), new B(), new C(), new D(), new E(), new T()]; | |
29 } | |
30 } catch (e) {} | |
31 } | |
32 | |
33 bla() { | |
34 var count = 0; | |
35 for (var x in make_array()) { | |
36 if (x is T) count++; | |
37 } | |
38 return count; | |
39 } | |
OLD | NEW |