Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 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 declaration has been made | 7 // This file relies on the fact that the following declaration has been made |
| 8 // in runtime.js: | 8 // in runtime.js: |
| 9 // var $Array = global.Array; | 9 // var $Array = global.Array; |
| 10 | 10 |
| (...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 116 if ((end - i) > 0 && ObjectIsFrozen(array)) { | 116 if ((end - i) > 0 && ObjectIsFrozen(array)) { |
| 117 throw MakeTypeError("array_functions_on_frozen", | 117 throw MakeTypeError("array_functions_on_frozen", |
| 118 ["Array.prototype.fill"]); | 118 ["Array.prototype.fill"]); |
| 119 } | 119 } |
| 120 | 120 |
| 121 for (; i < end; i++) | 121 for (; i < end; i++) |
| 122 array[i] = value; | 122 array[i] = value; |
| 123 return array; | 123 return array; |
| 124 } | 124 } |
| 125 | 125 |
| 126 // Proposed for ES7 | |
| 127 // https://github.com/domenic/Array.prototype.contains/ | |
| 128 // 3fb531d074eddf5d23e0a46b57ea48932e1fac69 | |
| 129 function ArrayContains(searchElement /*, fromIndex */) { // length == 1 | |
|
caitp (gmail)
2014/09/18 01:28:31
arv@ has suggested using `%FunctionSetLength(funct
mathias
2014/09/18 06:13:07
Needs an extra space before `//`.
Dmitry Lomov (no reviews)
2014/09/18 06:26:45
Needs COERCIBLE check. (No strong preference on ho
domenic_domenicdenicola.com
2014/09/18 15:16:13
There is no COERCIBLE check in the spec for any of
Dmitry Lomov (no reviews)
2014/09/18 15:37:29
Hmm, I see. Could you file a bug?
| |
| 130 var O = ToObject(this); | |
| 131 var len = ToLength(O.length); | |
| 132 | |
| 133 if (len === 0) { | |
|
Dmitry Lomov (no reviews)
2014/09/18 06:26:45
Do you need this check? The below will work just f
domenic_domenicdenicola.com
2014/09/18 15:16:13
Yes, as otherwise we will trigger ToInteger on fro
Dmitry Lomov (no reviews)
2014/09/18 15:37:29
Got it.
| |
| 134 return false; | |
| 135 } | |
| 136 | |
| 137 var n = ToInteger(%_Arguments(1)); | |
| 138 | |
| 139 if (n >= len) { | |
|
Dmitry Lomov (no reviews)
2014/09/18 06:26:45
Do you need this check? 'while' below has a check
domenic_domenicdenicola.com
2014/09/18 15:16:13
Removed, tests still pass.
| |
| 140 return false; | |
| 141 } | |
| 142 | |
| 143 var k; | |
| 144 if (n >= 0) { | |
| 145 k = n; | |
| 146 } else { | |
| 147 k = len - MathAbs(n); | |
|
Dmitry Lomov (no reviews)
2014/09/18 06:26:45
Simply len + n?
domenic_domenicdenicola.com
2014/09/18 15:16:13
Weird, I wonder why the spec used abs for indexOf
| |
| 148 if (k < 0) { | |
| 149 k = 0; | |
| 150 } | |
| 151 } | |
| 152 | |
| 153 while (k < len) { | |
| 154 var elementK = O[k]; | |
| 155 if (SameValueZero(searchElement, elementK) === true) { | |
|
Dmitry Lomov (no reviews)
2014/09/18 06:26:45
=== true? Why not "if (SameValueZero(...))"
domenic_domenicdenicola.com
2014/09/18 15:16:13
Just going for spec-verbatimness. Will change.
| |
| 156 return true; | |
| 157 } | |
| 158 | |
| 159 ++k; | |
| 160 } | |
| 161 | |
| 162 return false; | |
| 163 } | |
| 164 | |
| 126 // ES6, draft 05-22-14, section 22.1.2.3 | 165 // ES6, draft 05-22-14, section 22.1.2.3 |
| 127 function ArrayOf() { | 166 function ArrayOf() { |
| 128 var length = %_ArgumentsLength(); | 167 var length = %_ArgumentsLength(); |
| 129 var constructor = this; | 168 var constructor = this; |
| 130 // TODO: Implement IsConstructor (ES6 section 7.2.5) | 169 // TODO: Implement IsConstructor (ES6 section 7.2.5) |
| 131 var array = IS_SPEC_FUNCTION(constructor) ? new constructor(length) : []; | 170 var array = IS_SPEC_FUNCTION(constructor) ? new constructor(length) : []; |
| 132 for (var i = 0; i < length; i++) { | 171 for (var i = 0; i < length; i++) { |
| 133 %AddElement(array, i, %_Arguments(i), NONE); | 172 %AddElement(array, i, %_Arguments(i), NONE); |
| 134 } | 173 } |
| 135 array.length = length; | 174 array.length = length; |
| 136 return array; | 175 return array; |
| 137 } | 176 } |
| 138 | 177 |
| 139 // ------------------------------------------------------------------- | 178 // ------------------------------------------------------------------- |
| 140 | 179 |
| 141 function HarmonyArrayExtendArrayPrototype() { | 180 function HarmonyArrayExtendArrayPrototype() { |
| 142 %CheckIsBootstrapping(); | 181 %CheckIsBootstrapping(); |
| 143 | 182 |
| 144 // Set up non-enumerable functions on the Array object. | 183 // Set up non-enumerable functions on the Array object. |
| 145 InstallFunctions($Array, DONT_ENUM, $Array( | 184 InstallFunctions($Array, DONT_ENUM, $Array( |
| 146 "of", ArrayOf | 185 "of", ArrayOf |
| 147 )); | 186 )); |
| 148 | 187 |
| 149 // Set up the non-enumerable functions on the Array prototype object. | 188 // Set up the non-enumerable functions on the Array prototype object. |
| 150 InstallFunctions($Array.prototype, DONT_ENUM, $Array( | 189 InstallFunctions($Array.prototype, DONT_ENUM, $Array( |
| 190 "contains", ArrayContains, | |
| 151 "find", ArrayFind, | 191 "find", ArrayFind, |
| 152 "findIndex", ArrayFindIndex, | 192 "findIndex", ArrayFindIndex, |
| 153 "fill", ArrayFill | 193 "fill", ArrayFill |
| 154 )); | 194 )); |
| 155 } | 195 } |
| 156 | 196 |
| 157 HarmonyArrayExtendArrayPrototype(); | 197 HarmonyArrayExtendArrayPrototype(); |
| OLD | NEW |