From da7114d2a6bc4ef43b516029db613c17e11129b0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Hannes=20Walln=C3=B6fer?= Date: Fri, 21 Oct 2016 10:02:09 +0200 Subject: [PATCH] 8168140: TypedArrays should implement ES6 iterator protocol Reviewed-by: sundar, lagergren --- .../internal/objects/ArrayIterator.java | 14 +++- .../nashorn/internal/objects/NativeArray.java | 8 +-- .../internal/objects/NativeFloat32Array.java | 11 +++ .../internal/objects/NativeFloat64Array.java | 11 +++ .../internal/objects/NativeInt16Array.java | 11 +++ .../internal/objects/NativeInt32Array.java | 11 +++ .../internal/objects/NativeInt8Array.java | 11 +++ .../internal/objects/NativeUint16Array.java | 11 +++ .../internal/objects/NativeUint32Array.java | 11 +++ .../internal/objects/NativeUint8Array.java | 11 +++ .../objects/NativeUint8ClampedArray.java | 11 +++ nashorn/test/script/basic/es6/JDK-8168140.js | 68 +++++++++++++++++++ 12 files changed, 184 insertions(+), 5 deletions(-) create mode 100644 nashorn/test/script/basic/es6/JDK-8168140.js diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/ArrayIterator.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/ArrayIterator.java index 6b890db3f24..1d600df2780 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/ArrayIterator.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/ArrayIterator.java @@ -47,13 +47,25 @@ public class ArrayIterator extends AbstractIterator { private final Global global; - ArrayIterator(final Object iteratedObject, final IterationKind iterationKind, final Global global) { + private ArrayIterator(final Object iteratedObject, final IterationKind iterationKind, final Global global) { super(global.getArrayIteratorPrototype(), $nasgenmap$); this.iteratedObject = iteratedObject instanceof ScriptObject ? (ScriptObject) iteratedObject : null; this.iterationKind = iterationKind; this.global = global; } + static ArrayIterator newArrayValueIterator(final Object iteratedObject) { + return new ArrayIterator(Global.toObject(iteratedObject), IterationKind.VALUE, Global.instance()); + } + + static ArrayIterator newArrayKeyIterator(final Object iteratedObject) { + return new ArrayIterator(Global.toObject(iteratedObject), IterationKind.KEY, Global.instance()); + } + + static ArrayIterator newArrayKeyValueIterator(final Object iteratedObject) { + return new ArrayIterator(Global.toObject(iteratedObject), IterationKind.KEY_VALUE, Global.instance()); + } + /** * 22.1.5.2.1 %ArrayIteratorPrototype%.next() * diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeArray.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeArray.java index b469cf7209f..357689a2f89 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeArray.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeArray.java @@ -1726,7 +1726,7 @@ public final class NativeArray extends ScriptObject implements OptimisticBuiltin */ @Function(attributes = Attribute.NOT_ENUMERABLE) public static Object entries(final Object self) { - return new ArrayIterator(Global.toObject(self), AbstractIterator.IterationKind.KEY_VALUE, Global.instance()); + return ArrayIterator.newArrayKeyValueIterator(self); } /** @@ -1737,7 +1737,7 @@ public final class NativeArray extends ScriptObject implements OptimisticBuiltin */ @Function(attributes = Attribute.NOT_ENUMERABLE) public static Object keys(final Object self) { - return new ArrayIterator(Global.toObject(self), AbstractIterator.IterationKind.KEY, Global.instance()); + return ArrayIterator.newArrayKeyIterator(self); } /** @@ -1748,7 +1748,7 @@ public final class NativeArray extends ScriptObject implements OptimisticBuiltin */ @Function(attributes = Attribute.NOT_ENUMERABLE) public static Object values(final Object self) { - return new ArrayIterator(Global.toObject(self), AbstractIterator.IterationKind.VALUE, Global.instance()); + return ArrayIterator.newArrayValueIterator(self); } /** @@ -1759,7 +1759,7 @@ public final class NativeArray extends ScriptObject implements OptimisticBuiltin */ @Function(attributes = Attribute.NOT_ENUMERABLE, name = "@@iterator") public static Object getIterator(final Object self) { - return new ArrayIterator(Global.toObject(self), AbstractIterator.IterationKind.VALUE, Global.instance()); + return ArrayIterator.newArrayValueIterator(self); } /** diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeFloat32Array.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeFloat32Array.java index 0f67ec40b2b..bf5f68c4f2b 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeFloat32Array.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeFloat32Array.java @@ -232,6 +232,17 @@ public final class NativeFloat32Array extends ArrayBufferView { return (NativeFloat32Array)ArrayBufferView.subarrayImpl(self, begin, end); } + /** + * ECMA 6 22.2.3.30 %TypedArray%.prototype [ @@iterator ] ( ) + * + * @param self the self reference + * @return an iterator over the array's values + */ + @Function(attributes = Attribute.NOT_ENUMERABLE, name = "@@iterator") + public static Object getIterator(final Object self) { + return ArrayIterator.newArrayValueIterator(self); + } + @Override protected ScriptObject getPrototype(final Global global) { return global.getFloat32ArrayPrototype(); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeFloat64Array.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeFloat64Array.java index de3d0f007fb..0a46907cdd7 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeFloat64Array.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeFloat64Array.java @@ -232,6 +232,17 @@ public final class NativeFloat64Array extends ArrayBufferView { return (NativeFloat64Array)ArrayBufferView.subarrayImpl(self, begin, end); } + /** + * ECMA 6 22.2.3.30 %TypedArray%.prototype [ @@iterator ] ( ) + * + * @param self the self reference + * @return an iterator over the array's values + */ + @Function(attributes = Attribute.NOT_ENUMERABLE, name = "@@iterator") + public static Object getIterator(final Object self) { + return ArrayIterator.newArrayValueIterator(self); + } + @Override protected ScriptObject getPrototype(final Global global) { return global.getFloat64ArrayPrototype(); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeInt16Array.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeInt16Array.java index 735e6a37f6b..4700e27506e 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeInt16Array.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeInt16Array.java @@ -225,6 +225,17 @@ public final class NativeInt16Array extends ArrayBufferView { return (NativeInt16Array)ArrayBufferView.subarrayImpl(self, begin, end); } + /** + * ECMA 6 22.2.3.30 %TypedArray%.prototype [ @@iterator ] ( ) + * + * @param self the self reference + * @return an iterator over the array's values + */ + @Function(attributes = Attribute.NOT_ENUMERABLE, name = "@@iterator") + public static Object getIterator(final Object self) { + return ArrayIterator.newArrayValueIterator(self); + } + @Override protected ScriptObject getPrototype(final Global global) { return global.getInt16ArrayPrototype(); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeInt32Array.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeInt32Array.java index 7eacedc9bc4..4292985d292 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeInt32Array.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeInt32Array.java @@ -224,6 +224,17 @@ public final class NativeInt32Array extends ArrayBufferView { return (NativeInt32Array)ArrayBufferView.subarrayImpl(self, begin, end); } + /** + * ECMA 6 22.2.3.30 %TypedArray%.prototype [ @@iterator ] ( ) + * + * @param self the self reference + * @return an iterator over the array's values + */ + @Function(attributes = Attribute.NOT_ENUMERABLE, name = "@@iterator") + public static Object getIterator(final Object self) { + return ArrayIterator.newArrayValueIterator(self); + } + @Override protected ScriptObject getPrototype(final Global global) { return global.getInt32ArrayPrototype(); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeInt8Array.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeInt8Array.java index 75fde20eb65..13f00581f34 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeInt8Array.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeInt8Array.java @@ -224,6 +224,17 @@ public final class NativeInt8Array extends ArrayBufferView { return (NativeInt8Array)ArrayBufferView.subarrayImpl(self, begin, end); } + /** + * ECMA 6 22.2.3.30 %TypedArray%.prototype [ @@iterator ] ( ) + * + * @param self the self reference + * @return an iterator over the array's values + */ + @Function(attributes = Attribute.NOT_ENUMERABLE, name = "@@iterator") + public static Object getIterator(final Object self) { + return ArrayIterator.newArrayValueIterator(self); + } + @Override protected ScriptObject getPrototype(final Global global) { return global.getInt8ArrayPrototype(); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint16Array.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint16Array.java index fb3a6671153..0dfd2754c4e 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint16Array.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint16Array.java @@ -229,6 +229,17 @@ public final class NativeUint16Array extends ArrayBufferView { return (NativeUint16Array)ArrayBufferView.subarrayImpl(self, begin, end); } + /** + * ECMA 6 22.2.3.30 %TypedArray%.prototype [ @@iterator ] ( ) + * + * @param self the self reference + * @return an iterator over the array's values + */ + @Function(attributes = Attribute.NOT_ENUMERABLE, name = "@@iterator") + public static Object getIterator(final Object self) { + return ArrayIterator.newArrayValueIterator(self); + } + @Override protected ScriptObject getPrototype(final Global global) { return global.getUint16ArrayPrototype(); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint32Array.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint32Array.java index 4d691b290e0..7b91eb28329 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint32Array.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint32Array.java @@ -244,6 +244,17 @@ public final class NativeUint32Array extends ArrayBufferView { return (NativeUint32Array)ArrayBufferView.subarrayImpl(self, begin, end); } + /** + * ECMA 6 22.2.3.30 %TypedArray%.prototype [ @@iterator ] ( ) + * + * @param self the self reference + * @return an iterator over the array's values + */ + @Function(attributes = Attribute.NOT_ENUMERABLE, name = "@@iterator") + public static Object getIterator(final Object self) { + return ArrayIterator.newArrayValueIterator(self); + } + @Override protected ScriptObject getPrototype(final Global global) { return global.getUint32ArrayPrototype(); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint8Array.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint8Array.java index 229099e629a..3b11a54bed0 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint8Array.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint8Array.java @@ -230,6 +230,17 @@ public final class NativeUint8Array extends ArrayBufferView { return (NativeUint8Array)ArrayBufferView.subarrayImpl(self, begin, end); } + /** + * ECMA 6 22.2.3.30 %TypedArray%.prototype [ @@iterator ] ( ) + * + * @param self the self reference + * @return an iterator over the array's values + */ + @Function(attributes = Attribute.NOT_ENUMERABLE, name = "@@iterator") + public static Object getIterator(final Object self) { + return ArrayIterator.newArrayValueIterator(self); + } + @Override protected ScriptObject getPrototype(final Global global) { return global.getUint8ArrayPrototype(); diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint8ClampedArray.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint8ClampedArray.java index 1bc0eace78d..2edf2a76635 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint8ClampedArray.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/objects/NativeUint8ClampedArray.java @@ -266,6 +266,17 @@ public final class NativeUint8ClampedArray extends ArrayBufferView { return (NativeUint8ClampedArray)ArrayBufferView.subarrayImpl(self, begin, end); } + /** + * ECMA 6 22.2.3.30 %TypedArray%.prototype [ @@iterator ] ( ) + * + * @param self the self reference + * @return an iterator over the array's values + */ + @Function(attributes = Attribute.NOT_ENUMERABLE, name = "@@iterator") + public static Object getIterator(final Object self) { + return ArrayIterator.newArrayValueIterator(self); + } + @Override protected ScriptObject getPrototype(final Global global) { return global.getUint8ClampedArrayPrototype(); diff --git a/nashorn/test/script/basic/es6/JDK-8168140.js b/nashorn/test/script/basic/es6/JDK-8168140.js new file mode 100644 index 00000000000..c94c70445cb --- /dev/null +++ b/nashorn/test/script/basic/es6/JDK-8168140.js @@ -0,0 +1,68 @@ +/* + * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/** + * JDK-8168140: TypedArrays should implement ES6 iterator protocol + * + * @test + * @run + * @option --language=es6 + */ + +let TypedArrayTypes = [ + Int8Array, + Uint8Array, + Uint8ClampedArray, + Int16Array, + Uint16Array, + Int32Array, + Uint32Array, + Float32Array, + Float64Array +]; + +let arrays = []; +let sum = 0; + +TypedArrayTypes.forEach(function(ArrayType) { + var a = new ArrayType(10); + for (let i = 0; i < a.length; i++) { + a[i] = i; + } + arrays.push(a); +}); + +Assert.assertTrue(arrays.length === 9); + +for (let array of arrays) { + + Assert.assertTrue(array.length === 10); + let count = 0; + + for (let value of array) { + Assert.assertTrue(value === count++); + sum += value; + } +} + +Assert.assertTrue(sum === 405);