8059211: Changed ArrayData.length accessor to use the protected field and fixed javadoc warnings related to this

Reviewed-by: attila, hannesw
This commit is contained in:
Marcus Lagergren 2014-09-26 18:47:20 +02:00
parent 50228a4342
commit 3d2c518ad8
30 changed files with 213 additions and 218 deletions

View File

@ -29,8 +29,8 @@
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/ */
import jdk.nashorn.api.scripting.AbstractJSObject;
import java.nio.DoubleBuffer; import java.nio.DoubleBuffer;
import jdk.nashorn.api.scripting.AbstractJSObject;
/** /**
* Simple class demonstrating pluggable script object * Simple class demonstrating pluggable script object
@ -112,6 +112,8 @@ public class BufferArray extends AbstractJSObject {
return true; return true;
} }
}; };
default:
break;
} }
return null; return null;
} }

View File

@ -27,7 +27,6 @@ package jdk.nashorn.internal.codegen;
import static jdk.nashorn.internal.codegen.CompilerConstants.ARGUMENTS_VAR; import static jdk.nashorn.internal.codegen.CompilerConstants.ARGUMENTS_VAR;
import static jdk.nashorn.internal.codegen.CompilerConstants.EXPLODED_ARGUMENT_PREFIX; import static jdk.nashorn.internal.codegen.CompilerConstants.EXPLODED_ARGUMENT_PREFIX;
import java.lang.invoke.MethodType; import java.lang.invoke.MethodType;
import java.util.ArrayDeque; import java.util.ArrayDeque;
import java.util.ArrayList; import java.util.ArrayList;
@ -35,7 +34,6 @@ import java.util.Deque;
import java.util.HashSet; import java.util.HashSet;
import java.util.List; import java.util.List;
import java.util.Set; import java.util.Set;
import jdk.nashorn.internal.ir.AccessNode; import jdk.nashorn.internal.ir.AccessNode;
import jdk.nashorn.internal.ir.CallNode; import jdk.nashorn.internal.ir.CallNode;
import jdk.nashorn.internal.ir.Expression; import jdk.nashorn.internal.ir.Expression;
@ -131,7 +129,7 @@ public final class ApplySpecialization extends NodeVisitor<LexicalContext> imple
@SuppressWarnings("serial") @SuppressWarnings("serial")
final UnsupportedOperationException uoe = new UnsupportedOperationException() { final UnsupportedOperationException uoe = new UnsupportedOperationException() {
@Override @Override
public Throwable fillInStackTrace() { public synchronized Throwable fillInStackTrace() {
return null; return null;
} }
}; };

View File

@ -38,7 +38,6 @@ import static jdk.nashorn.internal.ir.FunctionNode.CompilationState.SCOPE_DEPTHS
import static jdk.nashorn.internal.ir.FunctionNode.CompilationState.SPLIT; import static jdk.nashorn.internal.ir.FunctionNode.CompilationState.SPLIT;
import static jdk.nashorn.internal.ir.FunctionNode.CompilationState.SYMBOLS_ASSIGNED; import static jdk.nashorn.internal.ir.FunctionNode.CompilationState.SYMBOLS_ASSIGNED;
import static jdk.nashorn.internal.runtime.logging.DebugLogger.quote; import static jdk.nashorn.internal.runtime.logging.DebugLogger.quote;
import java.io.PrintWriter; import java.io.PrintWriter;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.EnumSet; import java.util.EnumSet;
@ -48,7 +47,6 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Map.Entry; import java.util.Map.Entry;
import java.util.Set; import java.util.Set;
import jdk.nashorn.internal.AssertsEnabled; import jdk.nashorn.internal.AssertsEnabled;
import jdk.nashorn.internal.codegen.Compiler.CompilationPhases; import jdk.nashorn.internal.codegen.Compiler.CompilationPhases;
import jdk.nashorn.internal.ir.FunctionNode; import jdk.nashorn.internal.ir.FunctionNode;
@ -627,7 +625,7 @@ enum CompilationPhase {
/** /**
* Start a compilation phase * Start a compilation phase
* @param compiler * @param compiler the compiler to use
* @param functionNode function to compile * @param functionNode function to compile
* @return function node * @return function node
*/ */

View File

@ -2134,6 +2134,8 @@ public class MethodEmitter implements Emitter {
load("Function"); load("Function");
invoke(ScriptRuntime.INVALIDATE_RESERVED_BUILTIN_NAME); invoke(ScriptRuntime.INVALIDATE_RESERVED_BUILTIN_NAME);
break; break;
default:
break;
} }
return this; return this;
} }

View File

@ -443,7 +443,7 @@ public final class OptimisticTypesPersistence {
// does not increase filesDeleted // does not increase filesDeleted
} }
files[i] = null; // gc eligible files[i] = null; // gc eligible
}; }
} }
private static Path[] getAllRegularFilesInLastModifiedOrder() throws IOException { private static Path[] getAllRegularFilesInLastModifiedOrder() throws IOException {
@ -454,7 +454,7 @@ public final class OptimisticTypesPersistence {
@Override @Override
public boolean test(final Path path) { public boolean test(final Path path) {
return !Files.isDirectory(path); return !Files.isDirectory(path);
}; }
}) })
.map(new Function<Path, PathAndTime>() { .map(new Function<Path, PathAndTime>() {
@Override @Override

View File

@ -47,7 +47,6 @@ import static jdk.internal.org.objectweb.asm.Opcodes.T_DOUBLE;
import static jdk.internal.org.objectweb.asm.Opcodes.T_INT; import static jdk.internal.org.objectweb.asm.Opcodes.T_INT;
import static jdk.internal.org.objectweb.asm.Opcodes.T_LONG; import static jdk.internal.org.objectweb.asm.Opcodes.T_LONG;
import static jdk.nashorn.internal.codegen.CompilerConstants.staticCallNoLookup; import static jdk.nashorn.internal.codegen.CompilerConstants.staticCallNoLookup;
import java.io.DataInput; import java.io.DataInput;
import java.io.DataOutput; import java.io.DataOutput;
import java.io.IOException; import java.io.IOException;
@ -299,7 +298,7 @@ public abstract class Type implements Comparable<Type>, BytecodeOps {
* *
* @param typeMap the type map * @param typeMap the type map
* @param output data output * @param output data output
* @throws IOException * @throws IOException if write cannot be completed
*/ */
public static void writeTypeMap(final Map<Integer, Type> typeMap, final DataOutput output) throws IOException { public static void writeTypeMap(final Map<Integer, Type> typeMap, final DataOutput output) throws IOException {
if (typeMap == null) { if (typeMap == null) {
@ -329,7 +328,7 @@ public abstract class Type implements Comparable<Type>, BytecodeOps {
* *
* @param input data input * @param input data input
* @return type map * @return type map
* @throws IOException * @throws IOException if read cannot be completed
*/ */
public static Map<Integer, Type> readTypeMap(final DataInput input) throws IOException { public static Map<Integer, Type> readTypeMap(final DataInput input) throws IOException {
final int size = input.readInt(); final int size = input.readInt();

View File

@ -561,6 +561,7 @@ public final class Global extends ScriptObject implements Scope {
* *
* @param engine ScriptEngine to initialize * @param engine ScriptEngine to initialize
*/ */
@SuppressWarnings("hiding")
public void initBuiltinObjects(final ScriptEngine engine) { public void initBuiltinObjects(final ScriptEngine engine) {
if (this.builtinObject != null) { if (this.builtinObject != null) {
// already initialized, just return // already initialized, just return
@ -909,6 +910,8 @@ public final class Global extends ScriptObject implements Scope {
return sctxt; return sctxt;
case "engine": case "engine":
return global.engine; return global.engine;
default:
break;
} }
if (self == UNDEFINED) { if (self == UNDEFINED) {
@ -1715,6 +1718,7 @@ public final class Global extends ScriptObject implements Scope {
return func; return func;
} }
@SuppressWarnings("hiding")
private void init(final ScriptEngine engine) { private void init(final ScriptEngine engine) {
assert Context.getGlobal() == this : "this global is not set as current"; assert Context.getGlobal() == this : "this global is not set as current";

View File

@ -1835,7 +1835,7 @@ public final class NativeArray extends ScriptObject implements OptimisticBuiltin
return false; return false;
} }
private ContinuousArrayData getContinuousNonEmptyArrayData(final Object self) { private static ContinuousArrayData getContinuousNonEmptyArrayData(final Object self) {
final ContinuousArrayData data = getContinuousArrayData(self); final ContinuousArrayData data = getContinuousArrayData(self);
if (data != null) { if (data != null) {
return data.length() == 0 ? null : data; return data.length() == 0 ? null : data;

View File

@ -26,7 +26,6 @@
package jdk.nashorn.internal.objects; package jdk.nashorn.internal.objects;
import static jdk.nashorn.internal.runtime.ScriptRuntime.UNDEFINED; import static jdk.nashorn.internal.runtime.ScriptRuntime.UNDEFINED;
import java.io.PrintWriter; import java.io.PrintWriter;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.Objects; import java.util.Objects;
@ -262,8 +261,8 @@ public final class NativeDebug extends ScriptObject {
/** /**
* Set the event queue capacity * Set the event queue capacity
* @param self * @param self an event queue
* @param newCapacity * @param newCapacity new capacity
*/ */
@Function(attributes = Attribute.NOT_ENUMERABLE, where = Where.CONSTRUCTOR) @Function(attributes = Attribute.NOT_ENUMERABLE, where = Where.CONSTRUCTOR)
public static void setEventQueueCapacity(final Object self, final Object newCapacity) { public static void setEventQueueCapacity(final Object self, final Object newCapacity) {

View File

@ -77,7 +77,7 @@ public @interface SpecializedFunction {
public boolean isEmpty() { public boolean isEmpty() {
return true; return true;
} }
}; }
/** /**
* Get the class representing the empty link logic * Get the class representing the empty link logic

View File

@ -210,7 +210,7 @@ public abstract class CodeStore implements Loggable {
/** /**
* Constructor * Constructor
* *
* @throws IOException * @throws IOException if there are read/write problems with the cache and cache directory
*/ */
public DirectoryCodeStore() throws IOException { public DirectoryCodeStore() throws IOException {
this(Options.getStringProperty("nashorn.persistent.code.cache", "nashorn_code_cache"), false, DEFAULT_MIN_SIZE); this(Options.getStringProperty("nashorn.persistent.code.cache", "nashorn_code_cache"), false, DEFAULT_MIN_SIZE);
@ -222,7 +222,7 @@ public abstract class CodeStore implements Loggable {
* @param path directory to store code in * @param path directory to store code in
* @param readOnly is this a read only code store * @param readOnly is this a read only code store
* @param minSize minimum file size for caching scripts * @param minSize minimum file size for caching scripts
* @throws IOException * @throws IOException if there are read/write problems with the cache and cache directory
*/ */
public DirectoryCodeStore(final String path, final boolean readOnly, final int minSize) throws IOException { public DirectoryCodeStore(final String path, final boolean readOnly, final int minSize) throws IOException {
this.dir = checkDirectory(path, readOnly); this.dir = checkDirectory(path, readOnly);

View File

@ -110,9 +110,8 @@ final class CompiledFunction {
*/ */
this.invoker = MH.insertArguments(invoker, invoker.type().parameterCount() - 1, UnwarrantedOptimismException.FIRST_PROGRAM_POINT); this.invoker = MH.insertArguments(invoker, invoker.type().parameterCount() - 1, UnwarrantedOptimismException.FIRST_PROGRAM_POINT);
throw new AssertionError("Optimistic (UnwarrantedOptimismException throwing) builtin functions are currently not in use"); throw new AssertionError("Optimistic (UnwarrantedOptimismException throwing) builtin functions are currently not in use");
} else {
this.invoker = invoker;
} }
this.invoker = invoker;
this.constructor = constructor; this.constructor = constructor;
this.flags = flags; this.flags = flags;
this.callSiteType = callSiteType; this.callSiteType = callSiteType;
@ -510,8 +509,8 @@ final class CompiledFunction {
return ((ArrayType)paramTypes[paramTypes.length - 1]).getElementType(); return ((ArrayType)paramTypes[paramTypes.length - 1]).getElementType();
} }
boolean matchesCallSite(final MethodType callSiteType, final boolean pickVarArg) { boolean matchesCallSite(final MethodType other, final boolean pickVarArg) {
if (callSiteType.equals(this.callSiteType)) { if (other.equals(this.callSiteType)) {
return true; return true;
} }
final MethodType type = type(); final MethodType type = type();
@ -521,7 +520,7 @@ final class CompiledFunction {
return pickVarArg; return pickVarArg;
} }
final int csParamCount = getParamCount(callSiteType); final int csParamCount = getParamCount(other);
final boolean csIsVarArg = csParamCount == Integer.MAX_VALUE; final boolean csIsVarArg = csParamCount == Integer.MAX_VALUE;
final int thisThisIndex = needsCallee() ? 1 : 0; // Index of "this" parameter in this function's type final int thisThisIndex = needsCallee() ? 1 : 0; // Index of "this" parameter in this function's type
@ -530,7 +529,7 @@ final class CompiledFunction {
// We must match all incoming parameters, except "this". Starting from 1 to skip "this". // We must match all incoming parameters, except "this". Starting from 1 to skip "this".
for(int i = 1; i < minParams; ++i) { for(int i = 1; i < minParams; ++i) {
final Type fnType = Type.typeFor(type.parameterType(i + thisThisIndex)); final Type fnType = Type.typeFor(type.parameterType(i + thisThisIndex));
final Type csType = csIsVarArg ? Type.OBJECT : Type.typeFor(callSiteType.parameterType(i + 1)); final Type csType = csIsVarArg ? Type.OBJECT : Type.typeFor(other.parameterType(i + 1));
if(!fnType.isEquivalentTo(csType)) { if(!fnType.isEquivalentTo(csType)) {
return false; return false;
} }
@ -752,9 +751,9 @@ final class CompiledFunction {
return sb.toString(); return sb.toString();
} }
private void logRecompile(final String reason, final FunctionNode fn, final MethodType callSiteType, final Map<Integer, Type> ipp) { private void logRecompile(final String reason, final FunctionNode fn, final MethodType type, final Map<Integer, Type> ipp) {
if (log.isEnabled()) { if (log.isEnabled()) {
log.info(reason, DebugLogger.quote(fn.getName()), " signature: ", callSiteType, " ", toStringInvalidations(ipp)); log.info(reason, DebugLogger.quote(fn.getName()), " signature: ", type, " ", toStringInvalidations(ipp));
} }
} }

View File

@ -33,7 +33,6 @@ import static jdk.nashorn.internal.runtime.CodeStore.newCodeStore;
import static jdk.nashorn.internal.runtime.ECMAErrors.typeError; import static jdk.nashorn.internal.runtime.ECMAErrors.typeError;
import static jdk.nashorn.internal.runtime.ScriptRuntime.UNDEFINED; import static jdk.nashorn.internal.runtime.ScriptRuntime.UNDEFINED;
import static jdk.nashorn.internal.runtime.Source.sourceFor; import static jdk.nashorn.internal.runtime.Source.sourceFor;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.io.PrintWriter; import java.io.PrintWriter;
@ -64,9 +63,7 @@ import java.util.concurrent.atomic.AtomicLong;
import java.util.function.Consumer; import java.util.function.Consumer;
import java.util.function.Supplier; import java.util.function.Supplier;
import java.util.logging.Level; import java.util.logging.Level;
import javax.script.ScriptEngine; import javax.script.ScriptEngine;
import jdk.internal.org.objectweb.asm.ClassReader; import jdk.internal.org.objectweb.asm.ClassReader;
import jdk.internal.org.objectweb.asm.util.CheckClassAdapter; import jdk.internal.org.objectweb.asm.util.CheckClassAdapter;
import jdk.nashorn.api.scripting.ClassFilter; import jdk.nashorn.api.scripting.ClassFilter;
@ -1390,7 +1387,7 @@ public final class Context {
* logic to e.g. multiple switchpoint classes. * logic to e.g. multiple switchpoint classes.
*/ */
public static final class BuiltinSwitchPoint extends SwitchPoint { public static final class BuiltinSwitchPoint extends SwitchPoint {
//empty
} }
/** /**

View File

@ -26,7 +26,6 @@
package jdk.nashorn.internal.runtime; package jdk.nashorn.internal.runtime;
import static jdk.nashorn.internal.parser.TokenType.EOF; import static jdk.nashorn.internal.parser.TokenType.EOF;
import jdk.nashorn.internal.parser.Lexer; import jdk.nashorn.internal.parser.Lexer;
import jdk.nashorn.internal.parser.Token; import jdk.nashorn.internal.parser.Token;
import jdk.nashorn.internal.parser.TokenStream; import jdk.nashorn.internal.parser.TokenStream;
@ -42,11 +41,11 @@ public final class Debug {
/** /**
* Return the topmost JavaScript frame in a stack trace * Return the topmost JavaScript frame in a stack trace
* @param e * @param t throwable that contains the stack trace
* @return line describing the topmost JavaScript frame * @return line describing the topmost JavaScript frame
*/ */
public static String firstJSFrame(final Throwable e) { public static String firstJSFrame(final Throwable t) {
for (final StackTraceElement ste : e.getStackTrace()) { for (final StackTraceElement ste : t.getStackTrace()) {
if (ECMAErrors.isScriptFrame(ste)) { if (ECMAErrors.isScriptFrame(ste)) {
return ste.toString(); return ste.toString();
} }

View File

@ -501,13 +501,13 @@ public final class RecompilableScriptFunctionData extends ScriptFunctionData imp
for (final Map.Entry<String, byte[]> entry : classBytes.entrySet()) { for (final Map.Entry<String, byte[]> entry : classBytes.entrySet()) {
final String className = entry.getKey(); final String className = entry.getKey();
final byte[] code = entry.getValue(); final byte[] bytecode = entry.getValue();
if (className.equals(mainClassName)) { if (className.equals(mainClassName)) {
continue; continue;
} }
installedClasses.put(className, installer.install(className, code)); installedClasses.put(className, installer.install(className, bytecode));
} }
final Map<Integer, FunctionInitializer> initializers = script.getInitializers(); final Map<Integer, FunctionInitializer> initializers = script.getInitializers();
@ -588,9 +588,9 @@ public final class RecompilableScriptFunctionData extends ScriptFunctionData imp
return lookupCodeMethod(fn.getCompileUnit().getCode(), type); return lookupCodeMethod(fn.getCompileUnit().getCode(), type);
} }
MethodHandle lookupCodeMethod(final Class<?> code, final MethodType targetType) { MethodHandle lookupCodeMethod(final Class<?> codeClass, final MethodType targetType) {
log.info("Looking up ", DebugLogger.quote(name), " type=", targetType); log.info("Looking up ", DebugLogger.quote(name), " type=", targetType);
return MH.findStatic(LOOKUP, code, functionName, targetType); return MH.findStatic(LOOKUP, codeClass, functionName, targetType);
} }
/** /**

View File

@ -501,7 +501,7 @@ public abstract class ScriptFunction extends ScriptObject {
* @param linkLogicClass linkLogicClass, or null if no link logic exists * @param linkLogicClass linkLogicClass, or null if no link logic exists
* @return link logic instance, or null if one could not be constructed for this receiver * @return link logic instance, or null if one could not be constructed for this receiver
*/ */
private LinkLogic getLinkLogic(final Object self, final Class<? extends LinkLogic> linkLogicClass) { private static LinkLogic getLinkLogic(final Object self, final Class<? extends LinkLogic> linkLogicClass) {
if (linkLogicClass == null) { if (linkLogicClass == null) {
return LinkLogic.EMPTY_INSTANCE; //always OK to link this, specialization but without special linking logic return LinkLogic.EMPTY_INSTANCE; //always OK to link this, specialization but without special linking logic
} }

View File

@ -935,10 +935,10 @@ public abstract class ScriptObject implements PropertyAccess {
* creating setters that probably aren't used. Inject directly into the spill pool * creating setters that probably aren't used. Inject directly into the spill pool
* the defaults for "arguments" and "caller" * the defaults for "arguments" and "caller"
* *
* @param key * @param key property key
* @param propertyFlags * @param propertyFlags flags
* @param getter * @param getter getter for {@link UserAccessorProperty}, null if not present or N/A
* @param setter * @param setter setter for {@link UserAccessorProperty}, null if not present or N/A
*/ */
protected final void initUserAccessors(final String key, final int propertyFlags, final ScriptFunction getter, final ScriptFunction setter) { protected final void initUserAccessors(final String key, final int propertyFlags, final ScriptFunction getter, final ScriptFunction setter) {
final int slot = spillLength; final int slot = spillLength;
@ -1749,8 +1749,8 @@ public abstract class ScriptObject implements PropertyAccess {
*/ */
public Object put(final Object key, final Object value, final boolean strict) { public Object put(final Object key, final Object value, final boolean strict) {
final Object oldValue = get(key); final Object oldValue = get(key);
final int flags = strict ? NashornCallSiteDescriptor.CALLSITE_STRICT : 0; final int scriptObjectFlags = strict ? NashornCallSiteDescriptor.CALLSITE_STRICT : 0;
set(key, value, flags); set(key, value, scriptObjectFlags);
return oldValue; return oldValue;
} }
@ -1763,9 +1763,9 @@ public abstract class ScriptObject implements PropertyAccess {
* @param strict strict mode or not * @param strict strict mode or not
*/ */
public void putAll(final Map<?, ?> otherMap, final boolean strict) { public void putAll(final Map<?, ?> otherMap, final boolean strict) {
final int flags = strict ? NashornCallSiteDescriptor.CALLSITE_STRICT : 0; final int scriptObjectFlags = strict ? NashornCallSiteDescriptor.CALLSITE_STRICT : 0;
for (final Map.Entry<?, ?> entry : otherMap.entrySet()) { for (final Map.Entry<?, ?> entry : otherMap.entrySet()) {
set(entry.getKey(), entry.getValue(), flags); set(entry.getKey(), entry.getValue(), scriptObjectFlags);
} }
} }
@ -2046,7 +2046,7 @@ public abstract class ScriptObject implements PropertyAccess {
// Marks a property as declared and sets its value. Used as slow path for block-scoped LET and CONST // Marks a property as declared and sets its value. Used as slow path for block-scoped LET and CONST
@SuppressWarnings("unused") @SuppressWarnings("unused")
private void declareAndSet(final String key, final Object value) { private void declareAndSet(final String key, final Object value) {
final PropertyMap map = getMap(); final PropertyMap oldMap = getMap();
final FindProperty find = findProperty(key, false); final FindProperty find = findProperty(key, false);
assert find != null; assert find != null;
@ -2054,7 +2054,7 @@ public abstract class ScriptObject implements PropertyAccess {
assert property != null; assert property != null;
assert property.needsDeclaration(); assert property.needsDeclaration();
final PropertyMap newMap = map.replaceProperty(property, property.removeFlags(Property.NEEDS_DECLARATION)); final PropertyMap newMap = oldMap.replaceProperty(property, property.removeFlags(Property.NEEDS_DECLARATION));
setMap(newMap); setMap(newMap);
set(key, value, 0); set(key, value, 0);
} }

View File

@ -536,7 +536,7 @@ public abstract class ArrayData {
final Class<?> widest = widestType(items); final Class<?> widest = widestType(items);
ArrayData newData = convert(widest); ArrayData newData = convert(widest);
long pos = newData.length(); long pos = newData.length;
for (final Object item : items) { for (final Object item : items) {
newData = newData.ensure(pos); //avoid sparse array newData = newData.ensure(pos); //avoid sparse array
newData.set((int)pos++, item, strict); newData.set((int)pos++, item, strict);

View File

@ -39,7 +39,7 @@ abstract class ArrayFilter extends ArrayData {
protected ArrayData underlying; protected ArrayData underlying;
ArrayFilter(final ArrayData underlying) { ArrayFilter(final ArrayData underlying) {
super(underlying.length()); super(underlying.length);
this.underlying = underlying; this.underlying = underlying;
} }
@ -70,13 +70,13 @@ abstract class ArrayFilter extends ArrayData {
@Override @Override
public void shiftLeft(final int by) { public void shiftLeft(final int by) {
underlying.shiftLeft(by); underlying.shiftLeft(by);
setLength(underlying.length()); setLength(underlying.length);
} }
@Override @Override
public ArrayData shiftRight(final int by) { public ArrayData shiftRight(final int by) {
underlying = underlying.shiftRight(by); underlying = underlying.shiftRight(by);
setLength(underlying.length()); setLength(underlying.length);
return this; return this;
} }
@ -84,7 +84,7 @@ abstract class ArrayFilter extends ArrayData {
@Override @Override
public ArrayData ensure(final long safeIndex) { public ArrayData ensure(final long safeIndex) {
underlying = underlying.ensure(safeIndex); underlying = underlying.ensure(safeIndex);
setLength(underlying.length()); setLength(underlying.length);
return this; return this;
} }
@ -92,7 +92,7 @@ abstract class ArrayFilter extends ArrayData {
@Override @Override
public ArrayData shrink(final long newLength) { public ArrayData shrink(final long newLength) {
underlying = underlying.shrink(newLength); underlying = underlying.shrink(newLength);
setLength(underlying.length()); setLength(underlying.length);
return this; return this;
} }
@ -100,7 +100,7 @@ abstract class ArrayFilter extends ArrayData {
@Override @Override
public ArrayData set(final int index, final Object value, final boolean strict) { public ArrayData set(final int index, final Object value, final boolean strict) {
underlying = underlying.set(index, value, strict); underlying = underlying.set(index, value, strict);
setLength(underlying.length()); setLength(underlying.length);
return this; return this;
} }
@ -108,7 +108,7 @@ abstract class ArrayFilter extends ArrayData {
@Override @Override
public ArrayData set(final int index, final int value, final boolean strict) { public ArrayData set(final int index, final int value, final boolean strict) {
underlying = underlying.set(index, value, strict); underlying = underlying.set(index, value, strict);
setLength(underlying.length()); setLength(underlying.length);
return this; return this;
} }
@ -116,7 +116,7 @@ abstract class ArrayFilter extends ArrayData {
@Override @Override
public ArrayData set(final int index, final long value, final boolean strict) { public ArrayData set(final int index, final long value, final boolean strict) {
underlying = underlying.set(index, value, strict); underlying = underlying.set(index, value, strict);
setLength(underlying.length()); setLength(underlying.length);
return this; return this;
} }
@ -124,7 +124,7 @@ abstract class ArrayFilter extends ArrayData {
@Override @Override
public ArrayData set(final int index, final double value, final boolean strict) { public ArrayData set(final int index, final double value, final boolean strict) {
underlying = underlying.set(index, value, strict); underlying = underlying.set(index, value, strict);
setLength(underlying.length()); setLength(underlying.length);
return this; return this;
} }
@ -189,28 +189,28 @@ abstract class ArrayFilter extends ArrayData {
@Override @Override
public ArrayData delete(final int index) { public ArrayData delete(final int index) {
underlying = underlying.delete(index); underlying = underlying.delete(index);
setLength(underlying.length()); setLength(underlying.length);
return this; return this;
} }
@Override @Override
public ArrayData delete(final long from, final long to) { public ArrayData delete(final long from, final long to) {
underlying = underlying.delete(from, to); underlying = underlying.delete(from, to);
setLength(underlying.length()); setLength(underlying.length);
return this; return this;
} }
@Override @Override
public ArrayData convert(final Class<?> type) { public ArrayData convert(final Class<?> type) {
underlying = underlying.convert(type); underlying = underlying.convert(type);
setLength(underlying.length()); setLength(underlying.length);
return this; return this;
} }
@Override @Override
public Object pop() { public Object pop() {
final Object value = underlying.pop(); final Object value = underlying.pop();
setLength(underlying.length()); setLength(underlying.length);
return value; return value;
} }

View File

@ -76,11 +76,11 @@ public abstract class ContinuousArrayData extends ArrayData {
* array without reallocating, or if we are overwriting an already * array without reallocating, or if we are overwriting an already
* allocated element * allocated element
* *
* @param index * @param index index to check
* @return true if we don't need to do any array reallocation to fit an element at index * @return true if we don't need to do any array reallocation to fit an element at index
*/ */
public final boolean hasRoomFor(final int index) { public final boolean hasRoomFor(final int index) {
return has(index) || (index == length() && ensure(index) == this); return has(index) || (index == length && ensure(index) == this);
} }
/** /**

View File

@ -26,7 +26,6 @@
package jdk.nashorn.internal.runtime.arrays; package jdk.nashorn.internal.runtime.arrays;
import static jdk.nashorn.internal.runtime.ScriptRuntime.UNDEFINED; import static jdk.nashorn.internal.runtime.ScriptRuntime.UNDEFINED;
import java.lang.reflect.Array; import java.lang.reflect.Array;
import jdk.nashorn.internal.runtime.BitVector; import jdk.nashorn.internal.runtime.BitVector;
@ -40,7 +39,7 @@ final class DeletedArrayFilter extends ArrayFilter {
DeletedArrayFilter(final ArrayData underlying) { DeletedArrayFilter(final ArrayData underlying) {
super(underlying); super(underlying);
this.deleted = new BitVector(underlying.length()); this.deleted = new BitVector(underlying.length);
} }
@Override @Override
@ -80,25 +79,25 @@ final class DeletedArrayFilter extends ArrayFilter {
@Override @Override
public void shiftLeft(final int by) { public void shiftLeft(final int by) {
super.shiftLeft(by); super.shiftLeft(by);
deleted.shiftLeft(by, length()); deleted.shiftLeft(by, length);
} }
@Override @Override
public ArrayData shiftRight(final int by) { public ArrayData shiftRight(final int by) {
super.shiftRight(by); super.shiftRight(by);
deleted.shiftRight(by, length()); deleted.shiftRight(by, length);
return this; return this;
} }
@Override @Override
public ArrayData ensure(final long safeIndex) { public ArrayData ensure(final long safeIndex) {
if (safeIndex >= SparseArrayData.MAX_DENSE_LENGTH && safeIndex >= length()) { if (safeIndex >= SparseArrayData.MAX_DENSE_LENGTH && safeIndex >= length) {
return new SparseArrayData(this, safeIndex + 1); return new SparseArrayData(this, safeIndex + 1);
} }
super.ensure(safeIndex); super.ensure(safeIndex);
deleted.resize(length()); deleted.resize(length);
return this; return this;
} }
@ -106,7 +105,7 @@ final class DeletedArrayFilter extends ArrayFilter {
@Override @Override
public ArrayData shrink(final long newLength) { public ArrayData shrink(final long newLength) {
super.shrink(newLength); super.shrink(newLength);
deleted.resize(length()); deleted.resize(length);
return this; return this;
} }
@ -147,7 +146,7 @@ final class DeletedArrayFilter extends ArrayFilter {
@Override @Override
public ArrayData delete(final int index) { public ArrayData delete(final int index) {
final long longIndex = ArrayIndex.toLongIndex(index); final long longIndex = ArrayIndex.toLongIndex(index);
assert longIndex >= 0 && longIndex < length(); assert longIndex >= 0 && longIndex < length;
deleted.set(longIndex); deleted.set(longIndex);
underlying.setEmpty(index); underlying.setEmpty(index);
return this; return this;
@ -155,7 +154,7 @@ final class DeletedArrayFilter extends ArrayFilter {
@Override @Override
public ArrayData delete(final long fromIndex, final long toIndex) { public ArrayData delete(final long fromIndex, final long toIndex) {
assert fromIndex >= 0 && fromIndex <= toIndex && toIndex < length(); assert fromIndex >= 0 && fromIndex <= toIndex && toIndex < length;
deleted.setRange(fromIndex, toIndex + 1); deleted.setRange(fromIndex, toIndex + 1);
underlying.setEmpty(fromIndex, toIndex); underlying.setEmpty(fromIndex, toIndex);
return this; return this;
@ -163,7 +162,7 @@ final class DeletedArrayFilter extends ArrayFilter {
@Override @Override
public Object pop() { public Object pop() {
final long index = length() - 1; final long index = length - 1;
if (super.has((int)index)) { if (super.has((int)index)) {
final boolean isDeleted = deleted.isSet(index); final boolean isDeleted = deleted.isSet(index);
@ -180,7 +179,7 @@ final class DeletedArrayFilter extends ArrayFilter {
final ArrayData newArray = underlying.slice(from, to); final ArrayData newArray = underlying.slice(from, to);
final DeletedArrayFilter newFilter = new DeletedArrayFilter(newArray); final DeletedArrayFilter newFilter = new DeletedArrayFilter(newArray);
newFilter.getDeleted().copy(deleted); newFilter.getDeleted().copy(deleted);
newFilter.getDeleted().shiftLeft(from, newFilter.length()); newFilter.getDeleted().shiftLeft(from, newFilter.length);
return newFilter; return newFilter;
} }

View File

@ -45,7 +45,7 @@ final class DeletedRangeArrayFilter extends ArrayFilter {
if(hi < SparseArrayData.MAX_DENSE_LENGTH || underlying instanceof SparseArrayData) { if(hi < SparseArrayData.MAX_DENSE_LENGTH || underlying instanceof SparseArrayData) {
return underlying; return underlying;
} }
return new SparseArrayData(underlying, underlying.length()); return new SparseArrayData(underlying, underlying.length);
} }
private boolean isEmpty() { private boolean isEmpty() {
@ -93,7 +93,7 @@ final class DeletedRangeArrayFilter extends ArrayFilter {
@Override @Override
public ArrayData ensure(final long safeIndex) { public ArrayData ensure(final long safeIndex) {
if (safeIndex >= SparseArrayData.MAX_DENSE_LENGTH && safeIndex >= length()) { if (safeIndex >= SparseArrayData.MAX_DENSE_LENGTH && safeIndex >= length) {
return new SparseArrayData(this, safeIndex + 1); return new SparseArrayData(this, safeIndex + 1);
} }
@ -110,8 +110,9 @@ final class DeletedRangeArrayFilter extends ArrayFilter {
@Override @Override
public ArrayData shiftRight(final int by) { public ArrayData shiftRight(final int by) {
super.shiftRight(by); super.shiftRight(by);
lo = Math.min(length(), lo + by); final long len = length;
hi = Math.min(length() - 1, hi + by); lo = Math.min(len, lo + by);
hi = Math.min(len - 1, hi + by);
return isEmpty() ? getUnderlying() : this; return isEmpty() ? getUnderlying() : this;
} }
@ -237,7 +238,7 @@ final class DeletedRangeArrayFilter extends ArrayFilter {
@Override @Override
public Object pop() { public Object pop() {
final int index = (int)(length() - 1); final int index = (int)length - 1;
if (super.has(index)) { if (super.has(index)) {
final boolean isDeleted = isDeleted(index); final boolean isDeleted = isDeleted(index);
final Object value = super.pop(); final Object value = super.pop();

View File

@ -105,13 +105,13 @@ final class IntArrayData extends ContinuousArrayData implements IntElements {
@Override @Override
public ArrayData copy() { public ArrayData copy() {
return new IntArrayData(array.clone(), (int) length()); return new IntArrayData(array.clone(), (int)length);
} }
@Override @Override
public Object asArrayOfType(final Class<?> componentType) { public Object asArrayOfType(final Class<?> componentType) {
if (componentType == int.class) { if (componentType == int.class) {
return array.length == length() ? array.clone() : Arrays.copyOf(array, (int) length()); return array.length == length ? array.clone() : Arrays.copyOf(array, (int)length);
} }
return super.asArrayOfType(componentType); return super.asArrayOfType(componentType);
} }
@ -183,7 +183,7 @@ final class IntArrayData extends ContinuousArrayData implements IntElements {
@Override @Override
public ArrayData shiftRight(final int by) { public ArrayData shiftRight(final int by) {
final ArrayData newData = ensure(by + length() - 1); final ArrayData newData = ensure(by + length - 1);
if (newData != this) { if (newData != this) {
newData.shiftRight(by); newData.shiftRight(by);
return newData; return newData;
@ -229,7 +229,7 @@ final class IntArrayData extends ContinuousArrayData implements IntElements {
@Override @Override
public ArrayData set(final int index, final int value, final boolean strict) { public ArrayData set(final int index, final int value, final boolean strict) {
array[index] = value; array[index] = value;
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
@ -238,7 +238,7 @@ final class IntArrayData extends ContinuousArrayData implements IntElements {
public ArrayData set(final int index, final long value, final boolean strict) { public ArrayData set(final int index, final long value, final boolean strict) {
if (JSType.isRepresentableAsInt(value)) { if (JSType.isRepresentableAsInt(value)) {
array[index] = JSType.toInt32(value); array[index] = JSType.toInt32(value);
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
@ -249,7 +249,7 @@ final class IntArrayData extends ContinuousArrayData implements IntElements {
public ArrayData set(final int index, final double value, final boolean strict) { public ArrayData set(final int index, final double value, final boolean strict) {
if (JSType.isRepresentableAsInt(value)) { if (JSType.isRepresentableAsInt(value)) {
array[index] = (int)(long)value; array[index] = (int)(long)value;
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
@ -298,7 +298,7 @@ final class IntArrayData extends ContinuousArrayData implements IntElements {
@Override @Override
public boolean has(final int index) { public boolean has(final int index) {
return 0 <= index && index < length(); return 0 <= index && index < length;
} }
@Override @Override
@ -313,11 +313,11 @@ final class IntArrayData extends ContinuousArrayData implements IntElements {
@Override @Override
public Object pop() { public Object pop() {
if (length() == 0) { if (length == 0) {
return ScriptRuntime.UNDEFINED; return ScriptRuntime.UNDEFINED;
} }
final int newLength = (int) length() - 1; final int newLength = (int)length - 1;
final int elem = array[newLength]; final int elem = array[newLength];
array[newLength] = 0; array[newLength] = 0;
setLength(newLength); setLength(newLength);
@ -327,7 +327,7 @@ final class IntArrayData extends ContinuousArrayData implements IntElements {
@Override @Override
public ArrayData slice(final long from, final long to) { public ArrayData slice(final long from, final long to) {
final long start = from < 0 ? from + length() : from; final long start = from < 0 ? from + length : from;
final long newLength = to - start; final long newLength = to - start;
return new IntArrayData(Arrays.copyOfRange(array, (int)from, (int)to), (int)newLength); return new IntArrayData(Arrays.copyOfRange(array, (int)from, (int)to), (int)newLength);
@ -335,18 +335,18 @@ final class IntArrayData extends ContinuousArrayData implements IntElements {
@Override @Override
public final ArrayData push(final boolean strict, final int item) { public final ArrayData push(final boolean strict, final int item) {
final long length = length(); final long len = length;
final ArrayData newData = ensure(length); final ArrayData newData = ensure(len);
if (newData == this) { if (newData == this) {
array[(int)length] = item; array[(int)len] = item;
return this; return this;
} }
return newData.set((int)length, item, strict); return newData.set((int)len, item, strict);
} }
@Override @Override
public ArrayData fastSplice(final int start, final int removed, final int added) throws UnsupportedOperationException { public ArrayData fastSplice(final int start, final int removed, final int added) throws UnsupportedOperationException {
final long oldLength = length(); final long oldLength = length;
final long newLength = oldLength - removed + added; final long newLength = oldLength - removed + added;
if (newLength > SparseArrayData.MAX_DENSE_LENGTH && newLength > array.length) { if (newLength > SparseArrayData.MAX_DENSE_LENGTH && newLength > array.length) {
throw new UnsupportedOperationException(); throw new UnsupportedOperationException();

View File

@ -62,12 +62,12 @@ final class LongArrayData extends ContinuousArrayData implements IntOrLongElemen
@Override @Override
public ArrayData copy() { public ArrayData copy() {
return new LongArrayData(array.clone(), (int)length()); return new LongArrayData(array.clone(), (int)length);
} }
@Override @Override
public Object[] asObjectArray() { public Object[] asObjectArray() {
return toObjectArray(array, (int)length()); return toObjectArray(array, (int)length);
} }
private static Object[] toObjectArray(final long[] array, final int length) { private static Object[] toObjectArray(final long[] array, final int length) {
@ -84,7 +84,7 @@ final class LongArrayData extends ContinuousArrayData implements IntOrLongElemen
@Override @Override
public Object asArrayOfType(final Class<?> componentType) { public Object asArrayOfType(final Class<?> componentType) {
if (componentType == long.class) { if (componentType == long.class) {
return array.length == length() ? array.clone() : Arrays.copyOf(array, (int)length()); return array.length == length ? array.clone() : Arrays.copyOf(array, (int)length);
} }
return super.asArrayOfType(componentType); return super.asArrayOfType(componentType);
} }
@ -105,11 +105,11 @@ final class LongArrayData extends ContinuousArrayData implements IntOrLongElemen
if (type == Integer.class || type == Long.class) { if (type == Integer.class || type == Long.class) {
return this; return this;
} }
final int length = (int) length(); final int len = (int)length;
if (type == Double.class) { if (type == Double.class) {
return new NumberArrayData(LongArrayData.toDoubleArray(array, length), length); return new NumberArrayData(LongArrayData.toDoubleArray(array, len), len);
} }
return new ObjectArrayData(LongArrayData.toObjectArray(array, length), length); return new ObjectArrayData(LongArrayData.toObjectArray(array, len), len);
} }
@Override @Override
@ -119,7 +119,7 @@ final class LongArrayData extends ContinuousArrayData implements IntOrLongElemen
@Override @Override
public ArrayData shiftRight(final int by) { public ArrayData shiftRight(final int by) {
final ArrayData newData = ensure(by + length() - 1); final ArrayData newData = ensure(by + length - 1);
if (newData != this) { if (newData != this) {
newData.shiftRight(by); newData.shiftRight(by);
return newData; return newData;
@ -165,14 +165,14 @@ final class LongArrayData extends ContinuousArrayData implements IntOrLongElemen
@Override @Override
public ArrayData set(final int index, final int value, final boolean strict) { public ArrayData set(final int index, final int value, final boolean strict) {
array[index] = value; array[index] = value;
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
@Override @Override
public ArrayData set(final int index, final long value, final boolean strict) { public ArrayData set(final int index, final long value, final boolean strict) {
array[index] = value; array[index] = value;
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
@ -180,7 +180,7 @@ final class LongArrayData extends ContinuousArrayData implements IntOrLongElemen
public ArrayData set(final int index, final double value, final boolean strict) { public ArrayData set(final int index, final double value, final boolean strict) {
if (JSType.isRepresentableAsLong(value)) { if (JSType.isRepresentableAsLong(value)) {
array[index] = (long)value; array[index] = (long)value;
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
return convert(Double.class).set(index, value, strict); return convert(Double.class).set(index, value, strict);
@ -256,7 +256,7 @@ final class LongArrayData extends ContinuousArrayData implements IntOrLongElemen
@Override @Override
public boolean has(final int index) { public boolean has(final int index) {
return 0 <= index && index < length(); return 0 <= index && index < length;
} }
@Override @Override
@ -271,11 +271,11 @@ final class LongArrayData extends ContinuousArrayData implements IntOrLongElemen
@Override @Override
public Object pop() { public Object pop() {
if (length() == 0) { if (length == 0) {
return ScriptRuntime.UNDEFINED; return ScriptRuntime.UNDEFINED;
} }
final int newLength = (int) (length() - 1); final int newLength = (int)length - 1;
final long elem = array[newLength]; final long elem = array[newLength];
array[newLength] = 0; array[newLength] = 0;
setLength(newLength); setLength(newLength);
@ -285,25 +285,25 @@ final class LongArrayData extends ContinuousArrayData implements IntOrLongElemen
@Override @Override
public ArrayData slice(final long from, final long to) { public ArrayData slice(final long from, final long to) {
final long start = from < 0 ? from + length() : from; final long start = from < 0 ? from + length : from;
final long newLength = to - start; final long newLength = to - start;
return new LongArrayData(Arrays.copyOfRange(array, (int)from, (int)to), (int)newLength); return new LongArrayData(Arrays.copyOfRange(array, (int)from, (int)to), (int)newLength);
} }
@Override @Override
public final ArrayData push(final boolean strict, final long item) { public final ArrayData push(final boolean strict, final long item) {
final long length = length(); final long len = length;
final ArrayData newData = ensure(length); final ArrayData newData = ensure(len);
if (newData == this) { if (newData == this) {
array[(int)length] = item; array[(int)len] = item;
return this; return this;
} }
return newData.set((int)length, item, strict); return newData.set((int)len, item, strict);
} }
@Override @Override
public ArrayData fastSplice(final int start, final int removed, final int added) throws UnsupportedOperationException { public ArrayData fastSplice(final int start, final int removed, final int added) throws UnsupportedOperationException {
final long oldLength = length(); final long oldLength = length;
final long newLength = oldLength - removed + added; final long newLength = oldLength - removed + added;
if (newLength > SparseArrayData.MAX_DENSE_LENGTH && newLength > array.length) { if (newLength > SparseArrayData.MAX_DENSE_LENGTH && newLength > array.length) {
throw new UnsupportedOperationException(); throw new UnsupportedOperationException();
@ -353,7 +353,6 @@ final class LongArrayData extends ContinuousArrayData implements IntOrLongElemen
final long elem = array[newLength]; final long elem = array[newLength];
array[newLength] = 0; array[newLength] = 0;
return elem; return elem;
//return array[(int)--length];
} }
@Override @Override

View File

@ -58,19 +58,19 @@ final class NoTypeArrayData extends ArrayData {
@Override @Override
public ArrayData convert(final Class<?> type) { public ArrayData convert(final Class<?> type) {
final long length = length(); final long len = length;
final ArrayData arrayData; final ArrayData arrayData;
if (type == Long.class) { if (type == Long.class) {
arrayData = new LongArrayData(new long[ArrayData.nextSize((int)length)], (int)length); arrayData = new LongArrayData(new long[ArrayData.nextSize((int)len)], (int)len);
} else if (type == Double.class) { } else if (type == Double.class) {
arrayData = new NumberArrayData(new double[ArrayData.nextSize((int)length)], (int)length); arrayData = new NumberArrayData(new double[ArrayData.nextSize((int)len)], (int)len);
} else if (type == Integer.class) { } else if (type == Integer.class) {
arrayData = new IntArrayData(new int[ArrayData.nextSize((int)length)], (int)length); arrayData = new IntArrayData(new int[ArrayData.nextSize((int)len)], (int)len);
} else { } else {
assert !type.isPrimitive(); assert !type.isPrimitive();
arrayData = new ObjectArrayData(new Object[ArrayData.nextSize((int)length)], (int)length); arrayData = new ObjectArrayData(new Object[ArrayData.nextSize((int)len)], (int)len);
} }
return length == 0 ? arrayData : new DeletedRangeArrayFilter(arrayData, 0, length - 1); return length == 0 ? arrayData : new DeletedRangeArrayFilter(arrayData, 0, len - 1);
} }
@Override @Override
@ -90,11 +90,11 @@ final class NoTypeArrayData extends ArrayData {
} }
// Don't trample the shared EMPTY_ARRAY. // Don't trample the shared EMPTY_ARRAY.
if (length() == 0) { if (length == 0) {
return new NoTypeArrayData(Math.max(safeIndex + 1, length())); return new NoTypeArrayData(Math.max(safeIndex + 1, length));
} }
setLength(Math.max(safeIndex + 1, length())); setLength(Math.max(safeIndex + 1, length));
return this; return this;
} }

View File

@ -61,12 +61,12 @@ final class NumberArrayData extends ContinuousArrayData implements NumericElemen
@Override @Override
public ArrayData copy() { public ArrayData copy() {
return new NumberArrayData(array.clone(), (int) length()); return new NumberArrayData(array.clone(), (int)length);
} }
@Override @Override
public Object[] asObjectArray() { public Object[] asObjectArray() {
return toObjectArray(array, (int) length()); return toObjectArray(array, (int)length);
} }
private static Object[] toObjectArray(final double[] array, final int length) { private static Object[] toObjectArray(final double[] array, final int length) {
@ -82,7 +82,7 @@ final class NumberArrayData extends ContinuousArrayData implements NumericElemen
@Override @Override
public Object asArrayOfType(final Class<?> componentType) { public Object asArrayOfType(final Class<?> componentType) {
if(componentType == double.class) { if(componentType == double.class) {
return array.length == length() ? array.clone() : Arrays.copyOf(array, (int) length()); return array.length == length ? array.clone() : Arrays.copyOf(array, (int)length);
} }
return super.asArrayOfType(componentType); return super.asArrayOfType(componentType);
} }
@ -90,8 +90,8 @@ final class NumberArrayData extends ContinuousArrayData implements NumericElemen
@Override @Override
public ArrayData convert(final Class<?> type) { public ArrayData convert(final Class<?> type) {
if (type != Double.class && type != Integer.class && type != Long.class) { if (type != Double.class && type != Integer.class && type != Long.class) {
final int length = (int) length(); final int len = (int)length;
return new ObjectArrayData(NumberArrayData.toObjectArray(array, length), length); return new ObjectArrayData(NumberArrayData.toObjectArray(array, len), len);
} }
return this; return this;
} }
@ -103,7 +103,7 @@ final class NumberArrayData extends ContinuousArrayData implements NumericElemen
@Override @Override
public ArrayData shiftRight(final int by) { public ArrayData shiftRight(final int by) {
final ArrayData newData = ensure(by + length() - 1); final ArrayData newData = ensure(by + length - 1);
if (newData != this) { if (newData != this) {
newData.shiftRight(by); newData.shiftRight(by);
return newData; return newData;
@ -148,21 +148,21 @@ final class NumberArrayData extends ContinuousArrayData implements NumericElemen
@Override @Override
public ArrayData set(final int index, final int value, final boolean strict) { public ArrayData set(final int index, final int value, final boolean strict) {
array[index] = value; array[index] = value;
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
@Override @Override
public ArrayData set(final int index, final long value, final boolean strict) { public ArrayData set(final int index, final long value, final boolean strict) {
array[index] = value; array[index] = value;
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
@Override @Override
public ArrayData set(final int index, final double value, final boolean strict) { public ArrayData set(final int index, final double value, final boolean strict) {
array[index] = value; array[index] = value;
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
@ -231,7 +231,7 @@ final class NumberArrayData extends ContinuousArrayData implements NumericElemen
@Override @Override
public boolean has(final int index) { public boolean has(final int index) {
return 0 <= index && index < length(); return 0 <= index && index < length;
} }
@Override @Override
@ -246,11 +246,11 @@ final class NumberArrayData extends ContinuousArrayData implements NumericElemen
@Override @Override
public Object pop() { public Object pop() {
if (length() == 0) { if (length == 0) {
return UNDEFINED; return UNDEFINED;
} }
final int newLength = (int) (length() - 1); final int newLength = (int)length - 1;
final double elem = array[newLength]; final double elem = array[newLength];
array[newLength] = 0; array[newLength] = 0;
setLength(newLength); setLength(newLength);
@ -259,25 +259,25 @@ final class NumberArrayData extends ContinuousArrayData implements NumericElemen
@Override @Override
public ArrayData slice(final long from, final long to) { public ArrayData slice(final long from, final long to) {
final long start = from < 0 ? from + length() : from; final long start = from < 0 ? from + length : from;
final long newLength = to - start; final long newLength = to - start;
return new NumberArrayData(Arrays.copyOfRange(array, (int)from, (int)to), (int)newLength); return new NumberArrayData(Arrays.copyOfRange(array, (int)from, (int)to), (int)newLength);
} }
@Override @Override
public final ArrayData push(final boolean strict, final double item) { public final ArrayData push(final boolean strict, final double item) {
final long length = length(); final long len = length;
final ArrayData newData = ensure(length); final ArrayData newData = ensure(len);
if (newData == this) { if (newData == this) {
array[(int)length] = item; array[(int)len] = item;
return this; return this;
} }
return newData.set((int)length, item, strict); return newData.set((int)len, item, strict);
} }
@Override @Override
public ArrayData fastSplice(final int start, final int removed, final int added) throws UnsupportedOperationException { public ArrayData fastSplice(final int start, final int removed, final int added) throws UnsupportedOperationException {
final long oldLength = length(); final long oldLength = length;
final long newLength = oldLength - removed + added; final long newLength = oldLength - removed + added;
if (newLength > SparseArrayData.MAX_DENSE_LENGTH && newLength > array.length) { if (newLength > SparseArrayData.MAX_DENSE_LENGTH && newLength > array.length) {
throw new UnsupportedOperationException(); throw new UnsupportedOperationException();

View File

@ -67,14 +67,14 @@ final class ObjectArrayData extends ContinuousArrayData {
@Override @Override
public Object[] asObjectArray() { public Object[] asObjectArray() {
return array.length == length() ? array.clone() : asObjectArrayCopy(); return array.length == length ? array.clone() : asObjectArrayCopy();
} }
private Object[] asObjectArrayCopy() { private Object[] asObjectArrayCopy() {
final long l = length(); final long len = length;
assert l <= Integer.MAX_VALUE; assert len <= Integer.MAX_VALUE;
final Object[] copy = new Object[(int)l]; final Object[] copy = new Object[(int)len];
System.arraycopy(array, 0, copy, 0, (int)l); System.arraycopy(array, 0, copy, 0, (int)len);
return copy; return copy;
} }
@ -90,7 +90,7 @@ final class ObjectArrayData extends ContinuousArrayData {
@Override @Override
public ArrayData shiftRight(final int by) { public ArrayData shiftRight(final int by) {
final ArrayData newData = ensure(by + length() - 1); final ArrayData newData = ensure(by + length - 1);
if (newData != this) { if (newData != this) {
newData.shiftRight(by); newData.shiftRight(by);
return newData; return newData;
@ -122,28 +122,28 @@ final class ObjectArrayData extends ContinuousArrayData {
@Override @Override
public ArrayData set(final int index, final Object value, final boolean strict) { public ArrayData set(final int index, final Object value, final boolean strict) {
array[index] = value; array[index] = value;
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
@Override @Override
public ArrayData set(final int index, final int value, final boolean strict) { public ArrayData set(final int index, final int value, final boolean strict) {
array[index] = value; array[index] = value;
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
@Override @Override
public ArrayData set(final int index, final long value, final boolean strict) { public ArrayData set(final int index, final long value, final boolean strict) {
array[index] = value; array[index] = value;
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
@Override @Override
public ArrayData set(final int index, final double value, final boolean strict) { public ArrayData set(final int index, final double value, final boolean strict) {
array[index] = value; array[index] = value;
setLength(Math.max(index + 1, length())); setLength(Math.max(index + 1, length));
return this; return this;
} }
@ -220,7 +220,7 @@ final class ObjectArrayData extends ContinuousArrayData {
@Override @Override
public boolean has(final int index) { public boolean has(final int index) {
return 0 <= index && index < length(); return 0 <= index && index < length;
} }
@Override @Override
@ -273,11 +273,11 @@ final class ObjectArrayData extends ContinuousArrayData {
@Override @Override
public Object pop() { public Object pop() {
if (length() == 0) { if (length == 0) {
return ScriptRuntime.UNDEFINED; return ScriptRuntime.UNDEFINED;
} }
final int newLength = (int) (length() - 1); final int newLength = (int)length - 1;
final Object elem = array[newLength]; final Object elem = array[newLength];
setEmpty(newLength); setEmpty(newLength);
setLength(newLength); setLength(newLength);
@ -286,25 +286,25 @@ final class ObjectArrayData extends ContinuousArrayData {
@Override @Override
public ArrayData slice(final long from, final long to) { public ArrayData slice(final long from, final long to) {
final long start = from < 0 ? from + length() : from; final long start = from < 0 ? from + length : from;
final long newLength = to - start; final long newLength = to - start;
return new ObjectArrayData(Arrays.copyOfRange(array, (int)from, (int)to), (int)newLength); return new ObjectArrayData(Arrays.copyOfRange(array, (int)from, (int)to), (int)newLength);
} }
@Override @Override
public ArrayData push(final boolean strict, final Object item) { public ArrayData push(final boolean strict, final Object item) {
final long length = length(); final long len = length;
final ArrayData newData = ensure(length); final ArrayData newData = ensure(len);
if (newData == this) { if (newData == this) {
array[(int)length] = item; array[(int)len] = item;
return this; return this;
} }
return newData.set((int)length, item, strict); return newData.set((int)len, item, strict);
} }
@Override @Override
public ArrayData fastSplice(final int start, final int removed, final int added) throws UnsupportedOperationException { public ArrayData fastSplice(final int start, final int removed, final int added) throws UnsupportedOperationException {
final long oldLength = length(); final long oldLength = length;
final long newLength = oldLength - removed + added; final long newLength = oldLength - removed + added;
if (newLength > SparseArrayData.MAX_DENSE_LENGTH && newLength > array.length) { if (newLength > SparseArrayData.MAX_DENSE_LENGTH && newLength > array.length) {
throw new UnsupportedOperationException(); throw new UnsupportedOperationException();

View File

@ -53,28 +53,28 @@ class SparseArrayData extends ArrayData {
SparseArrayData(final ArrayData underlying, final long length, final TreeMap<Long, Object> sparseMap) { SparseArrayData(final ArrayData underlying, final long length, final TreeMap<Long, Object> sparseMap) {
super(length); super(length);
assert underlying.length() <= length; assert underlying.length <= length;
this.underlying = underlying; this.underlying = underlying;
this.maxDenseLength = Math.max(MAX_DENSE_LENGTH, underlying.length()); this.maxDenseLength = Math.max(MAX_DENSE_LENGTH, underlying.length);
this.sparseMap = sparseMap; this.sparseMap = sparseMap;
} }
@Override @Override
public ArrayData copy() { public ArrayData copy() {
return new SparseArrayData(underlying.copy(), length(), new TreeMap<>(sparseMap)); return new SparseArrayData(underlying.copy(), length, new TreeMap<>(sparseMap));
} }
@Override @Override
public Object[] asObjectArray() { public Object[] asObjectArray() {
final int length = (int) Math.min(length(), Integer.MAX_VALUE); final int len = (int)Math.min(length, Integer.MAX_VALUE);
final int underlyingLength = (int) Math.min(length, underlying.length()); final int underlyingLength = (int)Math.min(len, underlying.length);
final Object[] objArray = new Object[length]; final Object[] objArray = new Object[len];
for (int i = 0; i < underlyingLength; i++) { for (int i = 0; i < underlyingLength; i++) {
objArray[i] = underlying.getObject(i); objArray[i] = underlying.getObject(i);
} }
Arrays.fill(objArray, underlyingLength, length, ScriptRuntime.UNDEFINED); Arrays.fill(objArray, underlyingLength, len, ScriptRuntime.UNDEFINED);
for (final Map.Entry<Long, Object> entry : sparseMap.entrySet()) { for (final Map.Entry<Long, Object> entry : sparseMap.entrySet()) {
final long key = entry.getKey(); final long key = entry.getKey();
@ -104,14 +104,14 @@ class SparseArrayData extends ArrayData {
} }
sparseMap = newSparseMap; sparseMap = newSparseMap;
setLength(Math.max(length() - by, 0)); setLength(Math.max(length - by, 0));
} }
@Override @Override
public ArrayData shiftRight(final int by) { public ArrayData shiftRight(final int by) {
final TreeMap<Long, Object> newSparseMap = new TreeMap<>(); final TreeMap<Long, Object> newSparseMap = new TreeMap<>();
if (underlying.length() + by > maxDenseLength) { if (underlying.length + by > maxDenseLength) {
for (long i = maxDenseLength - by; i < underlying.length(); i++) { for (long i = maxDenseLength - by; i < underlying.length; i++) {
if (underlying.has((int) i)) { if (underlying.has((int) i)) {
newSparseMap.put(Long.valueOf(i + by), underlying.getObject((int) i)); newSparseMap.put(Long.valueOf(i + by), underlying.getObject((int) i));
} }
@ -127,23 +127,23 @@ class SparseArrayData extends ArrayData {
} }
sparseMap = newSparseMap; sparseMap = newSparseMap;
setLength(length() + by); setLength(length + by);
return this; return this;
} }
@Override @Override
public ArrayData ensure(final long safeIndex) { public ArrayData ensure(final long safeIndex) {
if (safeIndex < maxDenseLength && underlying.length() <= safeIndex) { if (safeIndex < maxDenseLength && underlying.length <= safeIndex) {
underlying = underlying.ensure(safeIndex); underlying = underlying.ensure(safeIndex);
} }
setLength(Math.max(safeIndex + 1, length())); setLength(Math.max(safeIndex + 1, length));
return this; return this;
} }
@Override @Override
public ArrayData shrink(final long newLength) { public ArrayData shrink(final long newLength) {
if (newLength < underlying.length()) { if (newLength < underlying.length) {
underlying = underlying.shrink(newLength); underlying = underlying.shrink(newLength);
underlying.setLength(newLength); underlying.setLength(newLength);
sparseMap.clear(); sparseMap.clear();
@ -160,11 +160,11 @@ class SparseArrayData extends ArrayData {
if (index >= 0 && index < maxDenseLength) { if (index >= 0 && index < maxDenseLength) {
ensure(index); ensure(index);
underlying = underlying.set(index, value, strict); underlying = underlying.set(index, value, strict);
setLength(Math.max(underlying.length(), length())); setLength(Math.max(underlying.length, length));
} else { } else {
final Long longIndex = indexToKey(index); final Long longIndex = indexToKey(index);
sparseMap.put(longIndex, value); sparseMap.put(longIndex, value);
setLength(Math.max(longIndex + 1, length())); setLength(Math.max(longIndex + 1, length));
} }
return this; return this;
@ -175,11 +175,11 @@ class SparseArrayData extends ArrayData {
if (index >= 0 && index < maxDenseLength) { if (index >= 0 && index < maxDenseLength) {
ensure(index); ensure(index);
underlying = underlying.set(index, value, strict); underlying = underlying.set(index, value, strict);
setLength(Math.max(underlying.length(), length())); setLength(Math.max(underlying.length, length));
} else { } else {
final Long longIndex = indexToKey(index); final Long longIndex = indexToKey(index);
sparseMap.put(longIndex, value); sparseMap.put(longIndex, value);
setLength(Math.max(longIndex + 1, length())); setLength(Math.max(longIndex + 1, length));
} }
return this; return this;
} }
@ -189,11 +189,11 @@ class SparseArrayData extends ArrayData {
if (index >= 0 && index < maxDenseLength) { if (index >= 0 && index < maxDenseLength) {
ensure(index); ensure(index);
underlying = underlying.set(index, value, strict); underlying = underlying.set(index, value, strict);
setLength(Math.max(underlying.length(), length())); setLength(Math.max(underlying.length, length));
} else { } else {
final Long longIndex = indexToKey(index); final Long longIndex = indexToKey(index);
sparseMap.put(longIndex, value); sparseMap.put(longIndex, value);
setLength(Math.max(longIndex + 1, length())); setLength(Math.max(longIndex + 1, length));
} }
return this; return this;
} }
@ -203,11 +203,11 @@ class SparseArrayData extends ArrayData {
if (index >= 0 && index < maxDenseLength) { if (index >= 0 && index < maxDenseLength) {
ensure(index); ensure(index);
underlying = underlying.set(index, value, strict); underlying = underlying.set(index, value, strict);
setLength(Math.max(underlying.length(), length())); setLength(Math.max(underlying.length, length));
} else { } else {
final Long longIndex = indexToKey(index); final Long longIndex = indexToKey(index);
sparseMap.put(longIndex, value); sparseMap.put(longIndex, value);
setLength(Math.max(longIndex + 1, length())); setLength(Math.max(longIndex + 1, length));
} }
return this; return this;
} }
@ -294,7 +294,7 @@ class SparseArrayData extends ArrayData {
@Override @Override
public boolean has(final int index) { public boolean has(final int index) {
if (index >= 0 && index < maxDenseLength) { if (index >= 0 && index < maxDenseLength) {
return index < underlying.length() && underlying.has(index); return index < underlying.length && underlying.has(index);
} }
return sparseMap.containsKey(indexToKey(index)); return sparseMap.containsKey(indexToKey(index));
@ -303,7 +303,7 @@ class SparseArrayData extends ArrayData {
@Override @Override
public ArrayData delete(final int index) { public ArrayData delete(final int index) {
if (index >= 0 && index < maxDenseLength) { if (index >= 0 && index < maxDenseLength) {
if (index < underlying.length()) { if (index < underlying.length) {
underlying = underlying.delete(index); underlying = underlying.delete(index);
} }
} else { } else {
@ -315,8 +315,8 @@ class SparseArrayData extends ArrayData {
@Override @Override
public ArrayData delete(final long fromIndex, final long toIndex) { public ArrayData delete(final long fromIndex, final long toIndex) {
if (fromIndex < maxDenseLength && fromIndex < underlying.length()) { if (fromIndex < maxDenseLength && fromIndex < underlying.length) {
underlying = underlying.delete(fromIndex, Math.min(toIndex, underlying.length() - 1)); underlying = underlying.delete(fromIndex, Math.min(toIndex, underlying.length - 1));
} }
if (toIndex >= maxDenseLength) { if (toIndex >= maxDenseLength) {
sparseMap.subMap(fromIndex, true, toIndex, true).clear(); sparseMap.subMap(fromIndex, true, toIndex, true).clear();
@ -336,30 +336,30 @@ class SparseArrayData extends ArrayData {
@Override @Override
public Object pop() { public Object pop() {
if (length() == 0) { if (length == 0) {
return ScriptRuntime.UNDEFINED; return ScriptRuntime.UNDEFINED;
} }
if (length() == underlying.length()) { if (length == underlying.length) {
final Object result = underlying.pop(); final Object result = underlying.pop();
setLength(underlying.length()); setLength(underlying.length);
return result; return result;
} }
setLength(length() - 1); setLength(length - 1);
final Long key = Long.valueOf(length()); final Long key = Long.valueOf(length);
return sparseMap.containsKey(key) ? sparseMap.remove(key) : ScriptRuntime.UNDEFINED; return sparseMap.containsKey(key) ? sparseMap.remove(key) : ScriptRuntime.UNDEFINED;
} }
@Override @Override
public ArrayData slice(final long from, final long to) { public ArrayData slice(final long from, final long to) {
assert to <= length(); assert to <= length;
final long start = from < 0 ? (from + length()) : from; final long start = from < 0 ? (from + length) : from;
final long newLength = to - start; final long newLength = to - start;
if (start >= 0 && to <= maxDenseLength) { if (start >= 0 && to <= maxDenseLength) {
if (newLength <= underlying.length()) { if (newLength <= underlying.length) {
return underlying.slice(from, to); return underlying.slice(from, to);
} }
return underlying.slice(from, to).ensure(newLength - 1).delete(underlying.length(), newLength); return underlying.slice(from, to).ensure(newLength - 1).delete(underlying.length, newLength);
} }
ArrayData sliced = EMPTY_ARRAY; ArrayData sliced = EMPTY_ARRAY;
@ -369,13 +369,13 @@ class SparseArrayData extends ArrayData {
sliced = sliced.set((int)(i - start), getObject((int)i), false); sliced = sliced.set((int)(i - start), getObject((int)i), false);
} }
} }
assert sliced.length() == newLength; assert sliced.length == newLength;
return sliced; return sliced;
} }
@Override @Override
public long nextIndex(final long index) { public long nextIndex(final long index) {
if (index < underlying.length() - 1) { if (index < underlying.length - 1) {
return underlying.nextIndex(index); return underlying.nextIndex(index);
} }
@ -383,6 +383,6 @@ class SparseArrayData extends ArrayData {
if (nextKey != null) { if (nextKey != null) {
return nextKey; return nextKey;
} }
return length(); return length;
} }
} }

View File

@ -54,11 +54,11 @@ public abstract class TypedArrayData<T extends Buffer> extends ContinuousArrayDa
} }
/** /**
* Length in elements. Accessed from {@code ArrayBufferView} * Length in number of elements. Accessed from {@code ArrayBufferView}
* @return element length * @return element length
*/ */
public final int getElementLength() { public final int getElementLength() {
return (int)length(); return (int)length;
} }
/** /**
@ -119,7 +119,7 @@ public abstract class TypedArrayData<T extends Buffer> extends ContinuousArrayDa
@Override @Override
public final boolean has(final int index) { public final boolean has(final int index) {
return 0 <= index && index < length(); return 0 <= index && index < length;
} }
@Override @Override

View File

@ -26,7 +26,6 @@
package jdk.nashorn.internal.runtime.arrays; package jdk.nashorn.internal.runtime.arrays;
import static jdk.nashorn.internal.runtime.ScriptRuntime.UNDEFINED; import static jdk.nashorn.internal.runtime.ScriptRuntime.UNDEFINED;
import java.lang.reflect.Array; import java.lang.reflect.Array;
import jdk.nashorn.internal.runtime.BitVector; import jdk.nashorn.internal.runtime.BitVector;
import jdk.nashorn.internal.runtime.UnwarrantedOptimismException; import jdk.nashorn.internal.runtime.UnwarrantedOptimismException;
@ -41,7 +40,7 @@ final class UndefinedArrayFilter extends ArrayFilter {
UndefinedArrayFilter(final ArrayData underlying) { UndefinedArrayFilter(final ArrayData underlying) {
super(underlying); super(underlying);
this.undefined = new BitVector(underlying.length()); this.undefined = new BitVector(underlying.length);
} }
@Override @Override
@ -81,25 +80,25 @@ final class UndefinedArrayFilter extends ArrayFilter {
@Override @Override
public void shiftLeft(final int by) { public void shiftLeft(final int by) {
super.shiftLeft(by); super.shiftLeft(by);
undefined.shiftLeft(by, length()); undefined.shiftLeft(by, length);
} }
@Override @Override
public ArrayData shiftRight(final int by) { public ArrayData shiftRight(final int by) {
super.shiftRight(by); super.shiftRight(by);
undefined.shiftRight(by, length()); undefined.shiftRight(by, length);
return this; return this;
} }
@Override @Override
public ArrayData ensure(final long safeIndex) { public ArrayData ensure(final long safeIndex) {
if (safeIndex >= SparseArrayData.MAX_DENSE_LENGTH && safeIndex >= length()) { if (safeIndex >= SparseArrayData.MAX_DENSE_LENGTH && safeIndex >= length) {
return new SparseArrayData(this, safeIndex + 1); return new SparseArrayData(this, safeIndex + 1);
} }
super.ensure(safeIndex); super.ensure(safeIndex);
undefined.resize(length()); undefined.resize(length);
return this; return this;
} }
@ -107,7 +106,7 @@ final class UndefinedArrayFilter extends ArrayFilter {
@Override @Override
public ArrayData shrink(final long newLength) { public ArrayData shrink(final long newLength) {
super.shrink(newLength); super.shrink(newLength);
undefined.resize(length()); undefined.resize(length);
return this; return this;
} }
@ -217,7 +216,7 @@ final class UndefinedArrayFilter extends ArrayFilter {
@Override @Override
public Object pop() { public Object pop() {
final long index = length() - 1; final long index = length - 1;
if (super.has((int)index)) { if (super.has((int)index)) {
final boolean isUndefined = undefined.isSet(index); final boolean isUndefined = undefined.isSet(index);
@ -234,7 +233,7 @@ final class UndefinedArrayFilter extends ArrayFilter {
final ArrayData newArray = underlying.slice(from, to); final ArrayData newArray = underlying.slice(from, to);
final UndefinedArrayFilter newFilter = new UndefinedArrayFilter(newArray); final UndefinedArrayFilter newFilter = new UndefinedArrayFilter(newArray);
newFilter.getUndefined().copy(undefined); newFilter.getUndefined().copy(undefined);
newFilter.getUndefined().shiftLeft(from, newFilter.length()); newFilter.getUndefined().shiftLeft(from, newFilter.length);
return newFilter; return newFilter;
} }