OLD | NEW |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 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. | 3 // BSD-style license that can be found in the LICENSE file. |
4 // Test program for correct optimizations related to types fo allocated lists. | 4 // Test program for correct optimizations related to types fo allocated lists. |
5 | 5 |
6 import "package:expect/expect.dart"; | |
7 | |
8 main() { | 6 main() { |
9 // Trigger optimization of 'test' method. | 7 // Trigger optimization of 'test' method. |
10 for (int i = 0; i < 1000; i++) { | 8 for (int i = 0; i < 1000; i++) { |
11 test(2); | 9 test(2); |
12 } | 10 } |
13 } | 11 } |
14 | 12 |
15 | 13 |
16 test(n) { | 14 test(n) { |
17 var a = new List(); // Growable list. | 15 var a = new List(); // Growable list. |
18 var b = new List(10); // Fixed size list. | 16 var b = new List(10); // Fixed size list. |
19 var c = const [1, 2, 3, 4]; // Constant aray. | 17 var c = const [1, 2, 3, 4]; // Constant aray. |
20 // In optimized mode the class checks will be eliminated since the | 18 // In optimized mode the class checks will be eliminated since the |
21 // constructors above provide information about exact types. | 19 // constructors above provide information about exact types. |
22 a.add(4); | 20 a.add(4); |
23 b[0] = 5; | 21 b[0] = 5; |
24 Expect.equals(4, a[0]); | 22 Expect.equals(4, a[0]); |
25 Expect.equals(5, b[0]); | 23 Expect.equals(5, b[0]); |
26 // Test bound check elimination. | 24 // Test bound check elimination. |
27 Expect.equals(2, c[1]); | 25 Expect.equals(2, c[1]); |
28 // Test elimination of array length computation. | 26 // Test elimination of array length computation. |
29 var v = c[n]; | 27 var v = c[n]; |
30 Expect.equals(v, c[n]); | 28 Expect.equals(v, c[n]); |
31 } | 29 } |
OLD | NEW |