OLD | NEW |
1 // Copyright 2006-2008 the V8 project authors. All rights reserved. | 1 // Copyright 2006-2008 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 // This files contains runtime support implemented in JavaScript. | 5 // This files contains runtime support implemented in JavaScript. |
6 | 6 |
7 // CAUTION: Some of the functions specified in this file are called | 7 // CAUTION: Some of the functions specified in this file are called |
8 // directly from compiled code. These are the functions with names in | 8 // directly from compiled code. These are the functions with names in |
9 // ALL CAPS. The compiled code passes the first argument in 'this' and | 9 // ALL CAPS. The compiled code passes the first argument in 'this' and |
10 // it does not push the function onto the stack. This means that you | 10 // it does not push the function onto the stack. This means that you |
(...skipping 306 matching lines...) Loading... |
317 function DELETE(key, strict) { | 317 function DELETE(key, strict) { |
318 return %DeleteProperty(%ToObject(this), %ToName(key), strict); | 318 return %DeleteProperty(%ToObject(this), %ToName(key), strict); |
319 } | 319 } |
320 | 320 |
321 | 321 |
322 // ECMA-262, section 11.8.7, page 54. | 322 // ECMA-262, section 11.8.7, page 54. |
323 function IN(x) { | 323 function IN(x) { |
324 if (!IS_SPEC_OBJECT(x)) { | 324 if (!IS_SPEC_OBJECT(x)) { |
325 throw %MakeTypeError('invalid_in_operator_use', [this, x]); | 325 throw %MakeTypeError('invalid_in_operator_use', [this, x]); |
326 } | 326 } |
327 return %_IsNonNegativeSmi(this) ? | 327 if (%_IsNonNegativeSmi(this)) { |
328 %HasElement(x, this) : %HasProperty(x, %ToName(this)); | 328 if (IS_ARRAY(x) && %_HasFastPackedElements(x)) { |
| 329 return this < x.length; |
| 330 } |
| 331 return %HasElement(x, this); |
| 332 } |
| 333 return %HasProperty(x, %ToName(this)); |
329 } | 334 } |
330 | 335 |
331 | 336 |
332 // ECMA-262, section 11.8.6, page 54. To make the implementation more | 337 // ECMA-262, section 11.8.6, page 54. To make the implementation more |
333 // efficient, the return value should be zero if the 'this' is an | 338 // efficient, the return value should be zero if the 'this' is an |
334 // instance of F, and non-zero if not. This makes it possible to avoid | 339 // instance of F, and non-zero if not. This makes it possible to avoid |
335 // an expensive ToBoolean conversion in the generated code. | 340 // an expensive ToBoolean conversion in the generated code. |
336 function INSTANCE_OF(F) { | 341 function INSTANCE_OF(F) { |
337 var V = this; | 342 var V = this; |
338 if (!IS_SPEC_FUNCTION(F)) { | 343 if (!IS_SPEC_FUNCTION(F)) { |
(...skipping 317 matching lines...) Loading... |
656 return i; | 661 return i; |
657 } | 662 } |
658 | 663 |
659 | 664 |
660 // NOTE: Setting the prototype for Array must take place as early as | 665 // NOTE: Setting the prototype for Array must take place as early as |
661 // possible due to code generation for array literals. When | 666 // possible due to code generation for array literals. When |
662 // generating code for a array literal a boilerplate array is created | 667 // generating code for a array literal a boilerplate array is created |
663 // that is cloned when running the code. It is essential that the | 668 // that is cloned when running the code. It is essential that the |
664 // boilerplate gets the right prototype. | 669 // boilerplate gets the right prototype. |
665 %FunctionSetPrototype($Array, new $Array(0)); | 670 %FunctionSetPrototype($Array, new $Array(0)); |
OLD | NEW |