Commit d4e5851b authored by neis's avatar neis Committed by Commit bot

Make Array.prototype[Symbol.iterator] non-constructible.

R=adamk@chromium.org
BUG=v8:5237

Review-Url: https://codereview.chromium.org/2188753002
Cr-Commit-Position: refs/heads/master@{#38116}
parent 7f6839d6
...@@ -144,9 +144,11 @@ utils.InstallFunctions(GlobalArray.prototype, DONT_ENUM, [ ...@@ -144,9 +144,11 @@ utils.InstallFunctions(GlobalArray.prototype, DONT_ENUM, [
'keys', ArrayKeys 'keys', ArrayKeys
]); ]);
// TODO(adam): Remove this call once 'values' is in the above // TODO(adam): Remove these calls once 'values' is in the above
// InstallFunctions block, as it'll be redundant. // InstallFunctions block, as they'll be redundant.
utils.SetFunctionName(ArrayValues, 'values'); utils.SetFunctionName(ArrayValues, 'values');
%FunctionRemovePrototype(ArrayValues);
%SetNativeFlag(ArrayValues);
%AddNamedProperty(GlobalArray.prototype, iteratorSymbol, ArrayValues, %AddNamedProperty(GlobalArray.prototype, iteratorSymbol, ArrayValues,
DONT_ENUM); DONT_ENUM);
......
...@@ -13,3 +13,4 @@ assertTrue(valuesDesc.configurable); ...@@ -13,3 +13,4 @@ assertTrue(valuesDesc.configurable);
assertTrue(valuesDesc.writable); assertTrue(valuesDesc.writable);
assertFalse(valuesDesc.enumerable); assertFalse(valuesDesc.enumerable);
assertTrue(Array.prototype[Symbol.unscopables].values); assertTrue(Array.prototype[Symbol.unscopables].values);
assertThrows(() => new Array.prototype[Symbol.iterator], TypeError);
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment