Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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 "use strict"; | 5 "use strict"; |
| 6 | 6 |
| 7 // This file relies on the fact that the following declarations have been made | 7 // This file relies on the fact that the following declarations have been made |
| 8 // in runtime.js: | 8 // in runtime.js: |
| 9 // var $Array = global.Array; | 9 // var $Array = global.Array; |
| 10 | 10 |
| (...skipping 1376 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1387 CHECK_OBJECT_COERCIBLE(this, "Array.prototype.reduce"); | 1387 CHECK_OBJECT_COERCIBLE(this, "Array.prototype.reduce"); |
| 1388 | 1388 |
| 1389 // Pull out the length so that modifications to the length in the | 1389 // Pull out the length so that modifications to the length in the |
| 1390 // loop will not affect the looping and side effects are visible. | 1390 // loop will not affect the looping and side effects are visible. |
| 1391 var array = ToObject(this); | 1391 var array = ToObject(this); |
| 1392 var length = ToUint32(array.length); | 1392 var length = ToUint32(array.length); |
| 1393 | 1393 |
| 1394 if (!IS_SPEC_FUNCTION(callback)) { | 1394 if (!IS_SPEC_FUNCTION(callback)) { |
| 1395 throw MakeTypeError('called_non_callable', [callback]); | 1395 throw MakeTypeError('called_non_callable', [callback]); |
| 1396 } | 1396 } |
| 1397 if (length == 0 && IS_UNDEFINED(current)) { | |
| 1398 throw MakeTypeError('reduce_no_initial', []); | |
| 1399 } | |
|
wingo
2014/10/07 11:04:31
I think the test should be %_ArgumentsLength() < 2
arv (Not doing code reviews)
2014/10/07 14:16:02
Yup. The spec says: "If initialValue is present, t
Diego Pino
2014/10/09 10:18:57
What I intended to code with that line was step 7
| |
| 1397 | 1400 |
| 1398 var i = 0; | 1401 var i = 0; |
| 1399 find_initial: if (%_ArgumentsLength() < 2) { | 1402 find_initial: if (%_ArgumentsLength() < 2) { |
| 1400 for (; i < length; i++) { | 1403 for (; i < length; i++) { |
| 1401 current = array[i]; | 1404 if (i in array) { |
| 1402 if (!IS_UNDEFINED(current) || i in array) { | 1405 current = array[i++]; |
| 1403 i++; | |
| 1404 break find_initial; | 1406 break find_initial; |
| 1405 } | 1407 } |
| 1406 } | 1408 } |
| 1407 throw MakeTypeError('reduce_no_initial', []); | 1409 throw MakeTypeError('reduce_no_initial', []); |
| 1408 } | 1410 } |
| 1409 | 1411 |
| 1410 var receiver = %GetDefaultReceiver(callback); | 1412 var receiver = %GetDefaultReceiver(callback); |
| 1411 var stepping = DEBUG_IS_ACTIVE && %DebugCallbackSupportsStepping(callback); | 1413 var stepping = DEBUG_IS_ACTIVE && %DebugCallbackSupportsStepping(callback); |
| 1412 for (; i < length; i++) { | 1414 for (; i < length; i++) { |
| 1413 if (i in array) { | 1415 if (i in array) { |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 1424 CHECK_OBJECT_COERCIBLE(this, "Array.prototype.reduceRight"); | 1426 CHECK_OBJECT_COERCIBLE(this, "Array.prototype.reduceRight"); |
| 1425 | 1427 |
| 1426 // Pull out the length so that side effects are visible before the | 1428 // Pull out the length so that side effects are visible before the |
| 1427 // callback function is checked. | 1429 // callback function is checked. |
| 1428 var array = ToObject(this); | 1430 var array = ToObject(this); |
| 1429 var length = ToUint32(array.length); | 1431 var length = ToUint32(array.length); |
| 1430 | 1432 |
| 1431 if (!IS_SPEC_FUNCTION(callback)) { | 1433 if (!IS_SPEC_FUNCTION(callback)) { |
| 1432 throw MakeTypeError('called_non_callable', [callback]); | 1434 throw MakeTypeError('called_non_callable', [callback]); |
| 1433 } | 1435 } |
| 1436 if (length == 0 && IS_UNDEFINED(current)) { | |
| 1437 throw MakeTypeError('reduce_no_initial', []); | |
| 1438 } | |
|
wingo
2014/10/07 11:04:31
likewise
arv (Not doing code reviews)
2014/10/07 14:16:02
Yup. https://people.mozilla.org/~jorendorff/es6-dr
| |
| 1434 | 1439 |
| 1435 var i = length - 1; | 1440 var i = length - 1; |
| 1436 find_initial: if (%_ArgumentsLength() < 2) { | 1441 find_initial: if (%_ArgumentsLength() < 2) { |
| 1437 for (; i >= 0; i--) { | 1442 for (; i >= 0; i--) { |
| 1438 current = array[i]; | 1443 if (i in array) { |
| 1439 if (!IS_UNDEFINED(current) || i in array) { | 1444 current = array[i--]; |
| 1440 i--; | |
| 1441 break find_initial; | 1445 break find_initial; |
| 1442 } | 1446 } |
| 1443 } | 1447 } |
| 1444 throw MakeTypeError('reduce_no_initial', []); | 1448 throw MakeTypeError('reduce_no_initial', []); |
| 1445 } | 1449 } |
| 1446 | 1450 |
| 1447 var receiver = %GetDefaultReceiver(callback); | 1451 var receiver = %GetDefaultReceiver(callback); |
| 1448 var stepping = DEBUG_IS_ACTIVE && %DebugCallbackSupportsStepping(callback); | 1452 var stepping = DEBUG_IS_ACTIVE && %DebugCallbackSupportsStepping(callback); |
| 1449 for (; i >= 0; i--) { | 1453 for (; i >= 0; i--) { |
| 1450 if (i in array) { | 1454 if (i in array) { |
| (...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1547 )); | 1551 )); |
| 1548 | 1552 |
| 1549 SetUpLockedPrototype(InternalPackedArray, $Array(), $Array( | 1553 SetUpLockedPrototype(InternalPackedArray, $Array(), $Array( |
| 1550 "join", getFunction("join", ArrayJoin), | 1554 "join", getFunction("join", ArrayJoin), |
| 1551 "pop", getFunction("pop", ArrayPop), | 1555 "pop", getFunction("pop", ArrayPop), |
| 1552 "push", getFunction("push", ArrayPush) | 1556 "push", getFunction("push", ArrayPush) |
| 1553 )); | 1557 )); |
| 1554 } | 1558 } |
| 1555 | 1559 |
| 1556 SetUpArray(); | 1560 SetUpArray(); |
| OLD | NEW |