OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 // Flags: --allow-natives-syntax --nostress-opt --track-field-types | 5 // Flags: --allow-natives-syntax --nostress-opt --track-field-types |
6 | 6 |
7 (function() { | 7 (function() { |
8 var o = { text: "Hello World!" }; | 8 var o = { text: "Hello World!" }; |
9 function A() { | 9 function A() { |
| 10 // Assign twice to make the field non-constant. |
| 11 // TODO(ishell): update test once constant field tracking is done. |
| 12 this.a = {text: 'foo'}; |
10 this.a = o; | 13 this.a = o; |
11 } | 14 } |
12 function readA(x) { | 15 function readA(x) { |
13 return x.a; | 16 return x.a; |
14 } | 17 } |
15 var a = new A(); | 18 var a = new A(); |
16 assertUnoptimized(readA); | 19 assertUnoptimized(readA); |
17 readA(a); readA(a); readA(a); | 20 readA(a); readA(a); readA(a); |
18 %OptimizeFunctionOnNextCall(readA); | 21 %OptimizeFunctionOnNextCall(readA); |
19 assertEquals(readA(a), o); | 22 assertEquals(readA(a), o); |
(...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
100 x = JSON.parse('{"a":"Short"}'); | 103 x = JSON.parse('{"a":"Short"}'); |
101 })(); | 104 })(); |
102 | 105 |
103 (function() { | 106 (function() { |
104 var x = {y: {z: 1}}; | 107 var x = {y: {z: 1}}; |
105 x.y.z = 1.1; | 108 x.y.z = 1.1; |
106 })(); | 109 })(); |
107 | 110 |
108 (function() { | 111 (function() { |
109 function Foo(x) { this.x = x; } | 112 function Foo(x) { this.x = x; } |
| 113 // TODO(ishell): update test once constant field tracking is done. |
| 114 var f0 = new Foo({x: 0}); |
| 115 f0.x = {x: 0}; // make Foo.x non-constant here. |
110 var f1 = new Foo({x: 1}); | 116 var f1 = new Foo({x: 1}); |
111 var f2 = new Foo({x: 2}); | 117 var f2 = new Foo({x: 2}); |
112 var f3 = new Foo({x: 3}); | 118 var f3 = new Foo({x: 3}); |
113 function readX(f) { return f.x.x; } | 119 function readX(f) { return f.x.x; } |
114 assertEquals(readX(f1), 1); | 120 assertEquals(readX(f1), 1); |
115 assertEquals(readX(f2), 2); | 121 assertEquals(readX(f2), 2); |
116 assertUnoptimized(readX); | 122 assertUnoptimized(readX); |
117 %OptimizeFunctionOnNextCall(readX); | 123 %OptimizeFunctionOnNextCall(readX); |
118 assertEquals(readX(f3), 3); | 124 assertEquals(readX(f3), 3); |
119 assertOptimized(readX); | 125 assertOptimized(readX); |
(...skipping 16 matching lines...) Expand all Loading... |
136 })(); | 142 })(); |
137 | 143 |
138 (function() { | 144 (function() { |
139 function Narf(x) { this.x = x; } | 145 function Narf(x) { this.x = x; } |
140 var f1 = new Narf(1); | 146 var f1 = new Narf(1); |
141 var f2 = new Narf(2); | 147 var f2 = new Narf(2); |
142 var f3 = new Narf(3); | 148 var f3 = new Narf(3); |
143 function baz(f, y) { f.y = y; } | 149 function baz(f, y) { f.y = y; } |
144 baz(f1, {y: 9}); | 150 baz(f1, {y: 9}); |
145 baz(f2, {y: 9}); | 151 baz(f2, {y: 9}); |
| 152 baz(f2, {y: 9}); |
146 %OptimizeFunctionOnNextCall(baz); | 153 %OptimizeFunctionOnNextCall(baz); |
| 154 baz(f2, {y: 9}); |
147 baz(f3, {a: -1}); | 155 baz(f3, {a: -1}); |
148 assertUnoptimized(baz); | 156 assertUnoptimized(baz); |
149 })(); | 157 })(); |
150 | 158 |
151 (function() { | 159 (function() { |
152 function Foo(x) { this.x = x; this.a = x; } | 160 function Foo(x) { this.x = x; this.a = x; } |
153 function Bar(x) { this.x = x; this.b = x; } | 161 function Bar(x) { this.x = x; this.b = x; } |
154 function readA(o) { return o.x.a; } | 162 function readA(o) { return o.x.a; } |
155 var f = new Foo({a:1}); | 163 var f = new Foo({a:1}); |
156 var b = new Bar({a:2}); | 164 var b = new Bar({a:2}); |
157 assertEquals(readA(f), 1); | 165 assertEquals(readA(f), 1); |
158 assertEquals(readA(b), 2); | 166 assertEquals(readA(b), 2); |
159 assertEquals(readA(f), 1); | 167 assertEquals(readA(f), 1); |
160 assertEquals(readA(b), 2); | 168 assertEquals(readA(b), 2); |
161 %OptimizeFunctionOnNextCall(readA); | 169 %OptimizeFunctionOnNextCall(readA); |
162 assertEquals(readA(f), 1); | 170 assertEquals(readA(f), 1); |
163 assertEquals(readA(b), 2); | 171 assertEquals(readA(b), 2); |
164 assertOptimized(readA); | 172 assertOptimized(readA); |
165 f.a.y = 0; | 173 f.a.y = 0; |
166 assertUnoptimized(readA); | 174 assertUnoptimized(readA); |
167 })(); | 175 })(); |
OLD | NEW |