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 (function(global, utils, extrasUtils) { | 5 (function(global, utils, extrasUtils) { |
| 6 | 6 |
| 7 "use strict"; | 7 "use strict"; |
| 8 | 8 |
| 9 %CheckIsBootstrapping(); | 9 %CheckIsBootstrapping(); |
| 10 | 10 |
| (...skipping 25 matching lines...) Expand all Loading... | |
| 36 | 36 |
| 37 utils.ImportFromExperimental(function(from) { | 37 utils.ImportFromExperimental(function(from) { |
| 38 FLAG_harmony_species = from.FLAG_harmony_species; | 38 FLAG_harmony_species = from.FLAG_harmony_species; |
| 39 }); | 39 }); |
| 40 | 40 |
| 41 // ------------------------------------------------------------------- | 41 // ------------------------------------------------------------------- |
| 42 | 42 |
| 43 | 43 |
| 44 function ArraySpeciesCreate(array, length) { | 44 function ArraySpeciesCreate(array, length) { |
| 45 var constructor; | 45 var constructor; |
| 46 | |
| 47 length = INVERT_NEG_ZERO(length); | |
| 48 | |
| 46 if (FLAG_harmony_species) { | 49 if (FLAG_harmony_species) { |
| 47 constructor = %ArraySpeciesConstructor(array); | 50 constructor = %ArraySpeciesConstructor(array); |
| 48 } else { | 51 } else { |
| 49 constructor = GlobalArray; | 52 constructor = GlobalArray; |
| 50 } | 53 } |
| 51 return new constructor(length); | 54 return new constructor(length); |
| 52 } | 55 } |
| 53 | 56 |
| 54 | 57 |
| 55 function KeySortCompare(a, b) { | 58 function KeySortCompare(a, b) { |
| (...skipping 1130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1186 | 1189 |
| 1187 // For .indexOf, we don't need to pass in the number of arguments | 1190 // For .indexOf, we don't need to pass in the number of arguments |
| 1188 // at the callsite since ToInteger(undefined) == 0; however, for | 1191 // at the callsite since ToInteger(undefined) == 0; however, for |
| 1189 // .lastIndexOf, we need to pass it, since the behavior for passing | 1192 // .lastIndexOf, we need to pass it, since the behavior for passing |
| 1190 // undefined is 0 but for not including the argument is length-1. | 1193 // undefined is 0 but for not including the argument is length-1. |
| 1191 function InnerArrayIndexOf(array, element, index, length) { | 1194 function InnerArrayIndexOf(array, element, index, length) { |
| 1192 if (length == 0) return -1; | 1195 if (length == 0) return -1; |
| 1193 if (IS_UNDEFINED(index)) { | 1196 if (IS_UNDEFINED(index)) { |
| 1194 index = 0; | 1197 index = 0; |
| 1195 } else { | 1198 } else { |
| 1196 index = TO_INTEGER(index) + 0; // Add 0 to convert -0 to 0 | 1199 index = INVERT_NEG_ZERO(TO_INTEGER(index)); |
| 1197 // If index is negative, index from the end of the array. | 1200 // If index is negative, index from the end of the array. |
| 1198 if (index < 0) { | 1201 if (index < 0) { |
| 1199 index = length + index; | 1202 index = length + index; |
| 1200 // If index is still negative, search the entire array. | 1203 // If index is still negative, search the entire array. |
| 1201 if (index < 0) index = 0; | 1204 if (index < 0) index = 0; |
| 1202 } | 1205 } |
| 1203 } | 1206 } |
| 1204 var min = index; | 1207 var min = index; |
| 1205 var max = length; | 1208 var max = length; |
| 1206 if (UseSparseVariant(array, length, IS_ARRAY(array), max - min)) { | 1209 if (UseSparseVariant(array, length, IS_ARRAY(array), max - min)) { |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1248 var length = TO_LENGTH(this.length); | 1251 var length = TO_LENGTH(this.length); |
| 1249 return InnerArrayIndexOf(this, element, index, length); | 1252 return InnerArrayIndexOf(this, element, index, length); |
| 1250 } | 1253 } |
| 1251 | 1254 |
| 1252 | 1255 |
| 1253 function InnerArrayLastIndexOf(array, element, index, length, argumentsLength) { | 1256 function InnerArrayLastIndexOf(array, element, index, length, argumentsLength) { |
| 1254 if (length == 0) return -1; | 1257 if (length == 0) return -1; |
| 1255 if (argumentsLength < 2) { | 1258 if (argumentsLength < 2) { |
| 1256 index = length - 1; | 1259 index = length - 1; |
| 1257 } else { | 1260 } else { |
| 1258 index = TO_INTEGER(index) + 0; // Add 0 to convert -0 to 0 | 1261 index = TO_INTEGER(index) + 0; // Add 0 to convert -0 to 0 |
|
Dan Ehrenberg
2016/05/04 17:52:24
Also call the macro from here
| |
| 1259 // If index is negative, index from end of the array. | 1262 // If index is negative, index from end of the array. |
| 1260 if (index < 0) index += length; | 1263 if (index < 0) index += length; |
| 1261 // If index is still negative, do not search the array. | 1264 // If index is still negative, do not search the array. |
| 1262 if (index < 0) return -1; | 1265 if (index < 0) return -1; |
| 1263 else if (index >= length) index = length - 1; | 1266 else if (index >= length) index = length - 1; |
| 1264 } | 1267 } |
| 1265 var min = 0; | 1268 var min = 0; |
| 1266 var max = index; | 1269 var max = index; |
| 1267 if (UseSparseVariant(array, length, IS_ARRAY(array), index)) { | 1270 if (UseSparseVariant(array, length, IS_ARRAY(array), index)) { |
| 1268 %NormalizeElements(array); | 1271 %NormalizeElements(array); |
| (...skipping 521 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1790 %InstallToContext([ | 1793 %InstallToContext([ |
| 1791 "array_pop", ArrayPop, | 1794 "array_pop", ArrayPop, |
| 1792 "array_push", ArrayPush, | 1795 "array_push", ArrayPush, |
| 1793 "array_shift", ArrayShift, | 1796 "array_shift", ArrayShift, |
| 1794 "array_splice", ArraySplice, | 1797 "array_splice", ArraySplice, |
| 1795 "array_slice", ArraySlice, | 1798 "array_slice", ArraySlice, |
| 1796 "array_unshift", ArrayUnshift, | 1799 "array_unshift", ArrayUnshift, |
| 1797 ]); | 1800 ]); |
| 1798 | 1801 |
| 1799 }); | 1802 }); |
| OLD | NEW |