| 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 obj = newarraycase_onearg(0, 5); |
| 295 assertKind(elements_kind.fast_double, obj); |
| 296 // Now pass a length that forces the dictionary path. |
| 297 obj = newarraycase_onearg(100000, 5); |
| 298 assertKind(elements_kind.dictionary, obj); |
| 299 assertTrue(obj.length == 100000); |
| 300 |
| 284 // Verify that cross context calls work | 301 // Verify that cross context calls work |
| 285 var realmA = Realm.current(); | 302 var realmA = Realm.current(); |
| 286 var realmB = Realm.create(); | 303 var realmB = Realm.create(); |
| 287 assertEquals(0, realmA); | 304 assertEquals(0, realmA); |
| 288 assertEquals(1, realmB); | 305 assertEquals(1, realmB); |
| 289 | 306 |
| 290 function instanceof_check(type) { | 307 function instanceof_check(type) { |
| 291 assertTrue(new type() instanceof type); | 308 assertTrue(new type() instanceof type); |
| 292 assertTrue(new type(5) instanceof type); | 309 assertTrue(new type(5) instanceof type); |
| 293 assertTrue(new type(1,2,3) instanceof type); | 310 assertTrue(new type(1,2,3) instanceof type); |
| 294 } | 311 } |
| 295 | 312 |
| 296 var realmBArray = Realm.eval(realmB, "Array"); | 313 var realmBArray = Realm.eval(realmB, "Array"); |
| 297 instanceof_check(Array); | 314 instanceof_check(Array); |
| 298 instanceof_check(realmBArray); | 315 instanceof_check(realmBArray); |
| 299 %OptimizeFunctionOnNextCall(instanceof_check); | 316 %OptimizeFunctionOnNextCall(instanceof_check); |
| 300 instanceof_check(Array); | 317 instanceof_check(Array); |
| 301 instanceof_check(realmBArray); | 318 instanceof_check(realmBArray); |
| 302 assertTrue(2 != %GetOptimizationStatus(instanceof_check)); | 319 assertTrue(2 != %GetOptimizationStatus(instanceof_check)); |
| 303 } | 320 } |
| 304 } | 321 } |
| OLD | NEW |