OLD | NEW |
1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2011, 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 various optimizations and deoptimizations of optimizing compiler.. | 4 // Test various optimizations and deoptimizations of optimizing compiler.. |
5 | 5 |
6 addThem(a, b) { | 6 addThem(a, b) { |
7 return a + b; | 7 return a + b; |
8 } | 8 } |
9 | 9 |
10 isItInt(a) { | 10 isItInt(a) { |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
56 for (int i = -500; i < 500; i++) { | 56 for (int i = -500; i < 500; i++) { |
57 var r = doNeg(i); | 57 var r = doNeg(i); |
58 var p = doNeg(r); | 58 var p = doNeg(r); |
59 Expect.equals(i, p); | 59 Expect.equals(i, p); |
60 } | 60 } |
61 var maxSmi = (1 << 30) - 1; | 61 var maxSmi = (1 << 30) - 1; |
62 Expect.equals(maxSmi, doNeg(doNeg(maxSmi))); | 62 Expect.equals(maxSmi, doNeg(doNeg(maxSmi))); |
63 // Deoptimize because of overflow. | 63 // Deoptimize because of overflow. |
64 var minInt = -(1 << 30); | 64 var minInt = -(1 << 30); |
65 Expect.equals(minInt, doNeg(doNeg(minInt))); | 65 Expect.equals(minInt, doNeg(doNeg(minInt))); |
66 | 66 |
67 for (int i = 0; i < 1000; i++) { | 67 for (int i = 0; i < 1000; i++) { |
68 Expect.equals(false, doNot(true)); | 68 Expect.equals(false, doNot(true)); |
69 Expect.equals(true, doNot(doNot(true))); | 69 Expect.equals(true, doNot(doNot(true))); |
70 } | 70 } |
71 for (int i = 0; i < 1000; i++) { | 71 for (int i = 0; i < 1000; i++) { |
72 Expect.equals(-57, doBitNot(56)); | 72 Expect.equals(-57, doBitNot(56)); |
73 Expect.equals(55, doBitNot(-56)); | 73 Expect.equals(55, doBitNot(-56)); |
74 } | 74 } |
75 | 75 |
76 for (int i = 0; i < 2000; i++) { | 76 for (int i = 0; i < 2000; i++) { |
77 Expect.equals(-2.2, doNeg2(2.2)); | 77 Expect.equals(-2.2, doNeg2(2.2)); |
78 } | 78 } |
79 // Deoptimize. | 79 // Deoptimize. |
80 Expect.equals(-5, doNeg2(5)); | 80 Expect.equals(-5, doNeg2(5)); |
81 | 81 |
82 var fixed = new List.fixedLength(10); | 82 var fixed = new List(10); |
83 var growable = [1, 2, 3, 4, 5]; | 83 var growable = [1, 2, 3, 4, 5]; |
84 | 84 |
85 for (int i = 0; i < 2000; i++) { | 85 for (int i = 0; i < 2000; i++) { |
86 doStore1(fixed, 7); | 86 doStore1(fixed, 7); |
87 Expect.equals(7, fixed[1]); | 87 Expect.equals(7, fixed[1]); |
88 doStore2(growable, 12); | 88 doStore2(growable, 12); |
89 Expect.equals(12, growable[2]); | 89 Expect.equals(12, growable[2]); |
90 } | 90 } |
91 | 91 |
92 // Deoptimize. | 92 // Deoptimize. |
93 doStore1(growable, 8); | 93 doStore1(growable, 8); |
94 Expect.equals(8, growable[1]); | 94 Expect.equals(8, growable[1]); |
95 doStore2(fixed, 101); | 95 doStore2(fixed, 101); |
96 Expect.equals(101, fixed[2]); | 96 Expect.equals(101, fixed[2]); |
97 } | 97 } |
OLD | NEW |