OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 263 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
274 return a; | 274 return a; |
275 } | 275 } |
276 | 276 |
277 obj = newarraycase_list_smiobj(1); | 277 obj = newarraycase_list_smiobj(1); |
278 assertKind(elements_kind.fast_smi_only, obj); | 278 assertKind(elements_kind.fast_smi_only, obj); |
279 obj = newarraycase_list_smiobj("coates"); | 279 obj = newarraycase_list_smiobj("coates"); |
280 assertKind(elements_kind.fast, obj); | 280 assertKind(elements_kind.fast, obj); |
281 obj = newarraycase_list_smiobj(2); | 281 obj = newarraycase_list_smiobj(2); |
282 assertKind(elements_kind.fast, obj); | 282 assertKind(elements_kind.fast, obj); |
283 | 283 |
| 284 function newarraycase_onearg(len, value) { |
| 285 var a = new Array(len); |
| 286 a[0] = value; |
| 287 return a; |
| 288 } |
| 289 |
| 290 obj = newarraycase_onearg(5, 3.5); |
| 291 assertKind(elements_kind.fast_double, obj); |
| 292 obj = newarraycase_onearg(10, 5); |
| 293 assertKind(elements_kind.fast_double, obj); |
| 294 // Now pass a length that forces the dictionary path. |
| 295 obj = newarraycase_onearg(100000, 5); |
| 296 assertKind(elements_kind.dictionary, obj); |
| 297 assertTrue(obj.length == 100000); |
| 298 |
284 // Verify that cross context calls work | 299 // Verify that cross context calls work |
285 var realmA = Realm.current(); | 300 var realmA = Realm.current(); |
286 var realmB = Realm.create(); | 301 var realmB = Realm.create(); |
287 assertEquals(0, realmA); | 302 assertEquals(0, realmA); |
288 assertEquals(1, realmB); | 303 assertEquals(1, realmB); |
289 | 304 |
290 function instanceof_check(type) { | 305 function instanceof_check(type) { |
291 assertTrue(new type() instanceof type); | 306 assertTrue(new type() instanceof type); |
292 assertTrue(new type(5) instanceof type); | 307 assertTrue(new type(5) instanceof type); |
293 assertTrue(new type(1,2,3) instanceof type); | 308 assertTrue(new type(1,2,3) instanceof type); |
294 } | 309 } |
295 | 310 |
296 var realmBArray = Realm.eval(realmB, "Array"); | 311 var realmBArray = Realm.eval(realmB, "Array"); |
297 instanceof_check(Array); | 312 instanceof_check(Array); |
298 instanceof_check(realmBArray); | 313 instanceof_check(realmBArray); |
299 %OptimizeFunctionOnNextCall(instanceof_check); | 314 %OptimizeFunctionOnNextCall(instanceof_check); |
300 instanceof_check(Array); | 315 instanceof_check(Array); |
301 instanceof_check(realmBArray); | 316 instanceof_check(realmBArray); |
302 assertTrue(2 != %GetOptimizationStatus(instanceof_check)); | 317 assertTrue(2 != %GetOptimizationStatus(instanceof_check)); |
303 } | 318 } |
304 } | 319 } |
OLD | NEW |