From 7620f470688aef4eb962246ab4c78b6189cc7f28 Mon Sep 17 00:00:00 2001 From: Attila Szegedi Date: Thu, 3 Jul 2014 11:18:10 +0200 Subject: [PATCH] 8049222: JSType class exposes public mutable arrays Reviewed-by: hannesw, sundar --- .../internal/codegen/ObjectClassGenerator.java | 10 +++++----- .../jdk/nashorn/internal/runtime/JSType.java | 18 ++++++++++-------- .../internal/runtime/UserAccessorProperty.java | 2 +- 3 files changed, 16 insertions(+), 14 deletions(-) diff --git a/nashorn/src/jdk/nashorn/internal/codegen/ObjectClassGenerator.java b/nashorn/src/jdk/nashorn/internal/codegen/ObjectClassGenerator.java index 1c0ee63703e..815ce271bf6 100644 --- a/nashorn/src/jdk/nashorn/internal/codegen/ObjectClassGenerator.java +++ b/nashorn/src/jdk/nashorn/internal/codegen/ObjectClassGenerator.java @@ -550,7 +550,7 @@ public final class ObjectClassGenerator implements Loggable { } //no optimism here. we do unconditional conversion to types - private static MethodHandle createGetterInner(final Class forType, final Class type, final MethodHandle primitiveGetter, final MethodHandle objectGetter, final MethodHandle[] converters, final int programPoint) { + private static MethodHandle createGetterInner(final Class forType, final Class type, final MethodHandle primitiveGetter, final MethodHandle objectGetter, final List converters, final int programPoint) { final int fti = forType == null ? TYPE_UNDEFINED_INDEX : getAccessorTypeIndex(forType); final int ti = getAccessorTypeIndex(type); //this means fail if forType != type @@ -564,7 +564,7 @@ public final class ObjectClassGenerator implements Loggable { if (isOptimistic) { //return undefined if asking for object. otherwise throw UnwarrantedOptimismException if (ti == TYPE_OBJECT_INDEX) { - return MH.dropArguments(GET_UNDEFINED[TYPE_OBJECT_INDEX], 0, Object.class); + return MH.dropArguments(GET_UNDEFINED.get(TYPE_OBJECT_INDEX), 0, Object.class); } //throw exception return MH.asType( @@ -578,7 +578,7 @@ public final class ObjectClassGenerator implements Loggable { getter.type().changeReturnType(type)); } //return an undefined and coerce it to the appropriate type - return MH.dropArguments(GET_UNDEFINED[ti], 0, Object.class); + return MH.dropArguments(GET_UNDEFINED.get(ti), 0, Object.class); } assert forType != null; @@ -604,7 +604,7 @@ public final class ObjectClassGenerator implements Loggable { return MH.filterReturnValue( objectGetter, MH.insertArguments( - converters[ti], + converters.get(ti), 1, programPoint)); } @@ -631,7 +631,7 @@ public final class ObjectClassGenerator implements Loggable { final MethodHandle tgetter = getterForType(forType, primitiveGetter, objectGetter); if (fti == TYPE_OBJECT_INDEX) { if (fti != ti) { - return MH.filterReturnValue(tgetter, CONVERT_OBJECT[ti]); + return MH.filterReturnValue(tgetter, CONVERT_OBJECT.get(ti)); } return tgetter; } diff --git a/nashorn/src/jdk/nashorn/internal/runtime/JSType.java b/nashorn/src/jdk/nashorn/internal/runtime/JSType.java index 388761c4655..350c502a4f9 100644 --- a/nashorn/src/jdk/nashorn/internal/runtime/JSType.java +++ b/nashorn/src/jdk/nashorn/internal/runtime/JSType.java @@ -220,23 +220,23 @@ public enum JSType { public static final int TYPE_OBJECT_INDEX = 3; //getAccessorTypeIndex(Object.class); /** object conversion quickies with JS semantics - used for return value and parameter filter */ - public static final MethodHandle[] CONVERT_OBJECT = { + public static final List CONVERT_OBJECT = toUnmodifiableList( JSType.TO_INT32.methodHandle(), JSType.TO_UINT32.methodHandle(), JSType.TO_NUMBER.methodHandle(), null - }; + ); /** * object conversion quickies with JS semantics - used for return value and parameter filter, optimistic * throws exception upon incompatible type (asking for a narrower one than the storage) */ - public static final MethodHandle[] CONVERT_OBJECT_OPTIMISTIC = { + public static final List CONVERT_OBJECT_OPTIMISTIC = toUnmodifiableList( JSType.TO_INT32_OPTIMISTIC.methodHandle(), JSType.TO_LONG_OPTIMISTIC.methodHandle(), JSType.TO_NUMBER_OPTIMISTIC.methodHandle(), null - }; + ); /** The value of Undefined cast to an int32 */ public static final int UNDEFINED_INT = 0; @@ -249,12 +249,12 @@ public enum JSType { * Method handles for getters that return undefined coerced * to the appropriate type */ - public static final MethodHandle[] GET_UNDEFINED = new MethodHandle[] { + public static final List GET_UNDEFINED = toUnmodifiableList( MH.constant(int.class, UNDEFINED_INT), MH.constant(long.class, UNDEFINED_LONG), MH.constant(double.class, UNDEFINED_DOUBLE), - MH.constant(Object.class, Undefined.getUndefined()), - }; + MH.constant(Object.class, Undefined.getUndefined()) + ); private static final double INT32_LIMIT = 4294967296.0; @@ -1820,5 +1820,7 @@ public enum JSType { } } - + private static final List toUnmodifiableList(final MethodHandle... methodHandles) { + return Collections.unmodifiableList(Arrays.asList(methodHandles)); + } } diff --git a/nashorn/src/jdk/nashorn/internal/runtime/UserAccessorProperty.java b/nashorn/src/jdk/nashorn/internal/runtime/UserAccessorProperty.java index 0a29d8911a6..ff770ed543c 100644 --- a/nashorn/src/jdk/nashorn/internal/runtime/UserAccessorProperty.java +++ b/nashorn/src/jdk/nashorn/internal/runtime/UserAccessorProperty.java @@ -246,7 +246,7 @@ public final class UserAccessorProperty extends SpillProperty { MH.filterReturnValue( getter, MH.insertArguments( - CONVERT_OBJECT_OPTIMISTIC[getAccessorTypeIndex(type)], + CONVERT_OBJECT_OPTIMISTIC.get(getAccessorTypeIndex(type)), 1, programPoint)), getter.type().changeReturnType(type));