diff --git a/nashorn/buildtools/nasgen/build.xml b/nashorn/buildtools/nasgen/build.xml
index 60321430748..d05b4854052 100644
--- a/nashorn/buildtools/nasgen/build.xml
+++ b/nashorn/buildtools/nasgen/build.xml
@@ -40,10 +40,9 @@
-
+
diff --git a/nashorn/buildtools/nasgen/project.properties b/nashorn/buildtools/nasgen/project.properties
index 5963f68e5c3..794bda8a9eb 100644
--- a/nashorn/buildtools/nasgen/project.properties
+++ b/nashorn/buildtools/nasgen/project.properties
@@ -37,12 +37,11 @@ dist.dir=dist
dist.jar=${dist.dir}/nasgen.jar
dist.javadoc.dir=${dist.dir}/javadoc
-nashorn.dir=../../
-
javac.debug=true
-javac.classpath=\
- ${nashorn.dir}/build/classes
+nasgen.module.imports=\
+ java.base/jdk.internal.org.objectweb.asm=ALL-UNNAMED,\
+ java.base/jdk.internal.org.objectweb.asm.util=ALL-UNNAMED
meta.inf.dir=${src.dir}/META-INF
run.classpath=\
diff --git a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ClassGenerator.java b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ClassGenerator.java
index f01a1d15eac..9eb9f47e606 100644
--- a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ClassGenerator.java
+++ b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ClassGenerator.java
@@ -143,6 +143,9 @@ public class ClassGenerator {
try {
return super.getCommonSuperClass(type1, type2);
} catch (final RuntimeException | LinkageError e) {
+ if (MemberInfo.isScriptObject(type1) && MemberInfo.isScriptObject(type2)) {
+ return StringConstants.SCRIPTOBJECT_TYPE;
+ }
return StringConstants.OBJECT_TYPE;
}
}
diff --git a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/MemberInfo.java b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/MemberInfo.java
index 388ab9a294d..93247880603 100644
--- a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/MemberInfo.java
+++ b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/MemberInfo.java
@@ -26,14 +26,15 @@ package jdk.nashorn.internal.tools.nasgen;
import static jdk.nashorn.internal.tools.nasgen.StringConstants.OBJECT_ARRAY_DESC;
import static jdk.nashorn.internal.tools.nasgen.StringConstants.OBJECT_DESC;
+import static jdk.nashorn.internal.tools.nasgen.StringConstants.OBJ_PKG;
+import static jdk.nashorn.internal.tools.nasgen.StringConstants.RUNTIME_PKG;
+import static jdk.nashorn.internal.tools.nasgen.StringConstants.SCRIPTS_PKG;
import static jdk.nashorn.internal.tools.nasgen.StringConstants.SCRIPTOBJECT_DESC;
import static jdk.nashorn.internal.tools.nasgen.StringConstants.STRING_DESC;
import static jdk.nashorn.internal.tools.nasgen.StringConstants.TYPE_SYMBOL;
import jdk.internal.org.objectweb.asm.Opcodes;
import jdk.internal.org.objectweb.asm.Type;
-import jdk.nashorn.internal.objects.annotations.Where;
-import jdk.nashorn.internal.runtime.ScriptObject;
/**
* Details about a Java method or field annotated with any of the field/method
@@ -460,6 +461,40 @@ public final class MemberInfo implements Cloneable {
}
}
+ /**
+ * Returns if the given (internal) name of a class represents a ScriptObject subtype.
+ */
+ public static boolean isScriptObject(final String name) {
+ // very crude check for ScriptObject subtype!
+ if (name.startsWith(OBJ_PKG + "Native") ||
+ name.equals(OBJ_PKG + "Global") ||
+ name.equals(OBJ_PKG + "ArrayBufferView")) {
+ return true;
+ }
+
+ if (name.startsWith(RUNTIME_PKG)) {
+ final String simpleName = name.substring(name.lastIndexOf('/') + 1);
+ switch (simpleName) {
+ case "ScriptObject":
+ case "ScriptFunction":
+ case "NativeJavaPackage":
+ case "Scope":
+ return true;
+ }
+ }
+
+ if (name.startsWith(SCRIPTS_PKG)) {
+ final String simpleName = name.substring(name.lastIndexOf('/') + 1);
+ switch (simpleName) {
+ case "JD":
+ case "JO":
+ return true;
+ }
+ }
+
+ return false;
+ }
+
private static boolean isValidJSType(final Type type) {
return isJSPrimitiveType(type) || isJSObjectType(type);
}
@@ -488,20 +523,11 @@ public final class MemberInfo implements Cloneable {
}
private static boolean isScriptObject(final Type type) {
- if (type.getDescriptor().equals(SCRIPTOBJECT_DESC)) {
- return true;
+ if (type.getSort() != Type.OBJECT) {
+ return false;
}
- if (type.getSort() == Type.OBJECT) {
- try {
- final Class> clazz = Class.forName(type.getClassName(), false, MY_LOADER);
- return ScriptObject.class.isAssignableFrom(clazz);
- } catch (final ClassNotFoundException cnfe) {
- return false;
- }
- }
-
- return false;
+ return isScriptObject(type.getInternalName());
}
private void error(final String msg) {
diff --git a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/MethodGenerator.java b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/MethodGenerator.java
index 1a99d828991..a4a906b4037 100644
--- a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/MethodGenerator.java
+++ b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/MethodGenerator.java
@@ -77,6 +77,7 @@ import static jdk.internal.org.objectweb.asm.Opcodes.SASTORE;
import static jdk.internal.org.objectweb.asm.Opcodes.SIPUSH;
import static jdk.internal.org.objectweb.asm.Opcodes.SWAP;
import static jdk.nashorn.internal.tools.nasgen.StringConstants.INIT;
+import static jdk.nashorn.internal.tools.nasgen.StringConstants.OBJ_ANNO_PKG;
import static jdk.nashorn.internal.tools.nasgen.StringConstants.SPECIALIZATION_INIT2;
import static jdk.nashorn.internal.tools.nasgen.StringConstants.SPECIALIZATION_INIT3;
import static jdk.nashorn.internal.tools.nasgen.StringConstants.SPECIALIZATION_TYPE;
@@ -85,7 +86,6 @@ import java.util.List;
import jdk.internal.org.objectweb.asm.Handle;
import jdk.internal.org.objectweb.asm.MethodVisitor;
import jdk.internal.org.objectweb.asm.Type;
-import jdk.nashorn.internal.objects.annotations.SpecializedFunction.LinkLogic;
/**
* Base class for all method generating classes.
@@ -98,7 +98,7 @@ public class MethodGenerator extends MethodVisitor {
private final Type returnType;
private final Type[] argumentTypes;
- static final Type EMPTY_LINK_LOGIC_TYPE = Type.getType(LinkLogic.getEmptyLinkLogicClass());
+ static final Type EMPTY_LINK_LOGIC_TYPE = Type.getType("L" + OBJ_ANNO_PKG + "SpecializedFunction$LinkLogic$Empty;");
MethodGenerator(final MethodVisitor mv, final int access, final String name, final String descriptor) {
super(Main.ASM_VERSION, mv);
diff --git a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInfo.java b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInfo.java
index ca9a325ccc6..deeea331820 100644
--- a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInfo.java
+++ b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInfo.java
@@ -31,33 +31,31 @@ import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import jdk.internal.org.objectweb.asm.Type;
-import jdk.nashorn.internal.objects.annotations.Constructor;
-import jdk.nashorn.internal.objects.annotations.Function;
-import jdk.nashorn.internal.objects.annotations.Getter;
-import jdk.nashorn.internal.objects.annotations.Property;
-import jdk.nashorn.internal.objects.annotations.ScriptClass;
-import jdk.nashorn.internal.objects.annotations.Setter;
-import jdk.nashorn.internal.objects.annotations.SpecializedFunction;
-import jdk.nashorn.internal.objects.annotations.SpecializedFunction.LinkLogic;
-import jdk.nashorn.internal.objects.annotations.Where;
import jdk.nashorn.internal.tools.nasgen.MemberInfo.Kind;
+import static jdk.nashorn.internal.tools.nasgen.StringConstants.OBJ_ANNO_PKG;
+import static jdk.nashorn.internal.tools.nasgen.StringConstants.RUNTIME_PKG;
+
/**
* All annotation information from a class that is annotated with
* the annotation com.sun.oracle.objects.annotations.ScriptClass.
*
*/
public final class ScriptClassInfo {
+ private static String getTypeDescriptor(String pkg, String name) {
+ return "L" + pkg + name + ";";
+ }
+
// descriptors for various annotations
- static final String SCRIPT_CLASS_ANNO_DESC = Type.getDescriptor(ScriptClass.class);
- static final String CONSTRUCTOR_ANNO_DESC = Type.getDescriptor(Constructor.class);
- static final String FUNCTION_ANNO_DESC = Type.getDescriptor(Function.class);
- static final String GETTER_ANNO_DESC = Type.getDescriptor(Getter.class);
- static final String SETTER_ANNO_DESC = Type.getDescriptor(Setter.class);
- static final String PROPERTY_ANNO_DESC = Type.getDescriptor(Property.class);
- static final String WHERE_ENUM_DESC = Type.getDescriptor(Where.class);
- static final String LINK_LOGIC_DESC = Type.getDescriptor(LinkLogic.class);
- static final String SPECIALIZED_FUNCTION = Type.getDescriptor(SpecializedFunction.class);
+ static final String SCRIPT_CLASS_ANNO_DESC = getTypeDescriptor(OBJ_ANNO_PKG, "ScriptClass");
+ static final String CONSTRUCTOR_ANNO_DESC = getTypeDescriptor(OBJ_ANNO_PKG, "Constructor");
+ static final String FUNCTION_ANNO_DESC = getTypeDescriptor(OBJ_ANNO_PKG, "Function");
+ static final String GETTER_ANNO_DESC = getTypeDescriptor(OBJ_ANNO_PKG, "Getter");
+ static final String SETTER_ANNO_DESC = getTypeDescriptor(OBJ_ANNO_PKG, "Setter");
+ static final String PROPERTY_ANNO_DESC = getTypeDescriptor(OBJ_ANNO_PKG, "Property");
+ static final String WHERE_ENUM_DESC = getTypeDescriptor(OBJ_ANNO_PKG, "Where");
+ static final String LINK_LOGIC_DESC = getTypeDescriptor(OBJ_ANNO_PKG, "SpecializedFunction$LinkLogic");
+ static final String SPECIALIZED_FUNCTION = getTypeDescriptor(OBJ_ANNO_PKG, "SpecializedFunction");
static final Map annotations = new HashMap<>();
@@ -276,6 +274,7 @@ public final class ScriptClassInfo {
try {
memInfo.verify();
} catch (final Exception e) {
+ e.printStackTrace();
error(e.getMessage());
}
}
diff --git a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInfoCollector.java b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInfoCollector.java
index 97deda84478..4a14d80ea4e 100644
--- a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInfoCollector.java
+++ b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInfoCollector.java
@@ -41,7 +41,6 @@ import jdk.internal.org.objectweb.asm.FieldVisitor;
import jdk.internal.org.objectweb.asm.MethodVisitor;
import jdk.internal.org.objectweb.asm.Opcodes;
import jdk.internal.org.objectweb.asm.Type;
-import jdk.nashorn.internal.objects.annotations.Where;
import jdk.nashorn.internal.tools.nasgen.MemberInfo.Kind;
/**
diff --git a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInstrumentor.java b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInstrumentor.java
index 7f699fdf6b9..4bdb35867a3 100644
--- a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInstrumentor.java
+++ b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInstrumentor.java
@@ -50,7 +50,6 @@ import jdk.internal.org.objectweb.asm.ClassWriter;
import jdk.internal.org.objectweb.asm.FieldVisitor;
import jdk.internal.org.objectweb.asm.MethodVisitor;
import jdk.internal.org.objectweb.asm.util.CheckClassAdapter;
-import jdk.nashorn.internal.objects.annotations.Where;
import jdk.nashorn.internal.tools.nasgen.MemberInfo.Kind;
/**
diff --git a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/StringConstants.java b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/StringConstants.java
index 233b4f95dfd..428cece8a3f 100644
--- a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/StringConstants.java
+++ b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/StringConstants.java
@@ -31,25 +31,23 @@ import java.util.Collection;
import java.util.Collections;
import java.util.List;
import jdk.internal.org.objectweb.asm.Type;
-import jdk.nashorn.internal.objects.NativeSymbol;
-import jdk.nashorn.internal.runtime.AccessorProperty;
-import jdk.nashorn.internal.runtime.PropertyMap;
-import jdk.nashorn.internal.runtime.PrototypeObject;
-import jdk.nashorn.internal.runtime.ScriptFunction;
-import jdk.nashorn.internal.runtime.ScriptObject;
-import jdk.nashorn.internal.runtime.Specialization;
-import jdk.nashorn.internal.runtime.Symbol;
/**
* String constants used for code generation/instrumentation.
*/
@SuppressWarnings("javadoc")
public interface StringConstants {
+ static final String NASHORN_INTERNAL = "jdk/nashorn/internal/";
+ static final String OBJ_PKG = NASHORN_INTERNAL + "objects/";
+ static final String OBJ_ANNO_PKG = OBJ_PKG + "annotations/";
+ static final String RUNTIME_PKG = NASHORN_INTERNAL + "runtime/";
+ static final String SCRIPTS_PKG = NASHORN_INTERNAL + "scripts/";
+
// standard jdk types, methods
static final Type TYPE_METHODHANDLE = Type.getType(MethodHandle.class);
static final Type TYPE_METHODHANDLE_ARRAY = Type.getType(MethodHandle[].class);
- static final Type TYPE_SPECIALIZATION = Type.getType(Specialization.class);
- static final Type TYPE_SPECIALIZATION_ARRAY = Type.getType(Specialization[].class);
+ static final Type TYPE_SPECIALIZATION = Type.getType("L" + RUNTIME_PKG + "Specialization;");
+ static final Type TYPE_SPECIALIZATION_ARRAY = Type.getType("[L" + RUNTIME_PKG + "Specialization;");
static final Type TYPE_OBJECT = Type.getType(Object.class);
static final Type TYPE_STRING = Type.getType(String.class);
static final Type TYPE_CLASS = Type.getType(Class.class);
@@ -85,13 +83,13 @@ public interface StringConstants {
static final String LIST_DESC = TYPE_LIST.getDescriptor();
// Nashorn types, methods
- static final Type TYPE_ACCESSORPROPERTY = Type.getType(AccessorProperty.class);
- static final Type TYPE_PROPERTYMAP = Type.getType(PropertyMap.class);
- static final Type TYPE_PROTOTYPEOBJECT = Type.getType(PrototypeObject.class);
- static final Type TYPE_SCRIPTFUNCTION = Type.getType(ScriptFunction.class);
- static final Type TYPE_SCRIPTOBJECT = Type.getType(ScriptObject.class);
- static final Type TYPE_NATIVESYMBOL = Type.getType(NativeSymbol.class);
- static final Type TYPE_SYMBOL = Type.getType(Symbol.class);
+ static final Type TYPE_ACCESSORPROPERTY = Type.getType("L" + RUNTIME_PKG + "AccessorProperty;");
+ static final Type TYPE_PROPERTYMAP = Type.getType("L" + RUNTIME_PKG + "PropertyMap;");
+ static final Type TYPE_PROTOTYPEOBJECT = Type.getType("L" + RUNTIME_PKG + "PrototypeObject;");
+ static final Type TYPE_SCRIPTFUNCTION = Type.getType("L" + RUNTIME_PKG + "ScriptFunction;");
+ static final Type TYPE_SCRIPTOBJECT = Type.getType("L" + RUNTIME_PKG + "ScriptObject;");
+ static final Type TYPE_NATIVESYMBOL = Type.getType("L" + OBJ_PKG + "NativeSymbol;");
+ static final Type TYPE_SYMBOL = Type.getType("L" + RUNTIME_PKG + "Symbol;");
static final String PROTOTYPE_SUFFIX = "$Prototype";
static final String CONSTRUCTOR_SUFFIX = "$Constructor";
diff --git a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/Where.java b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/Where.java
new file mode 100644
index 00000000000..daaa2bc34a2
--- /dev/null
+++ b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/Where.java
@@ -0,0 +1,39 @@
+/*
+ * 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. Oracle designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Oracle in the LICENSE file that accompanied this code.
+ *
+ * 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.
+ */
+
+package jdk.nashorn.internal.tools.nasgen;
+
+/**
+ * Enum to tell where a Function or Property belongs.
+ * Note: keep this in sync. with jdk.nashorn.internal.objects.annotations.Where.
+ */
+public enum Where {
+ /** this means that the item belongs in the Constructor of an object */
+ CONSTRUCTOR,
+ /** this means that the item belongs in the Prototype of an object */
+ PROTOTYPE,
+ /** this means that the item belongs in the Instance of an object */
+ INSTANCE
+}
diff --git a/nashorn/make/BuildNashorn.gmk b/nashorn/make/BuildNashorn.gmk
index f4dcf3938e3..2d9a68e3c95 100644
--- a/nashorn/make/BuildNashorn.gmk
+++ b/nashorn/make/BuildNashorn.gmk
@@ -38,11 +38,14 @@ JDK_CLASSES := $(call PathList, $(strip $(addprefix $(JDK_OUTPUTDIR)/modules/, \
NASHORN_JAR := $(IMAGES_OUTPUTDIR)/nashorn.jar
+MODULESOURCEPATH := $(NASHORN_TOPDIR)/src/*/share/classes
+
# Need to use source and target 8 for nasgen to work.
$(eval $(call SetupJavaCompiler,GENERATE_NEWBYTECODE_DEBUG, \
JVM := $(JAVA), \
JAVAC := $(NEW_JAVAC), \
- FLAGS := -g -source 8 -target 8 -bootclasspath $(JDK_CLASSES), \
+ FLAGS := -g -source 9 -target 9 -upgrademodulepath "$(JDK_OUTPUTDIR)/modules/" \
+ -system none -modulesourcepath "$(MODULESOURCEPATH)", \
SERVER_DIR := $(SJAVAC_SERVER_DIR), \
SERVER_JVM := $(SJAVAC_SERVER_JAVA)))
@@ -52,10 +55,11 @@ $(eval $(call SetupJavaCompiler,GENERATE_NEWBYTECODE_DEBUG, \
# seamlessly.
$(eval $(call SetupJavaCompilation,jdk.scripting.nashorn, \
SETUP := GENERATE_NEWBYTECODE_DEBUG, \
+ MODULE := jdk.scripting.nashorn, \
SRC := $(NASHORN_TOPDIR)/src/jdk.scripting.nashorn/share/classes, \
EXCLUDE_FILES := META-INF/MANIFEST.MF, \
COPY := .properties .js, \
- BIN := $(SUPPORT_OUTPUTDIR)/special_classes/jdk.scripting.nashorn/classes))
+ BIN := $(SUPPORT_OUTPUTDIR)/special_classes))
NASGEN_SRC := $(NASHORN_TOPDIR)/buildtools/nasgen/src
ASM_SRC := $(JDK_TOPDIR)/src/java.base/share/classes/jdk/internal/org/objectweb/asm
@@ -64,24 +68,31 @@ ASM_SRC := $(JDK_TOPDIR)/src/java.base/share/classes/jdk/internal/org/objectweb/
$(eval $(call SetupJavaCompilation,BUILD_NASGEN, \
SETUP := GENERATE_OLDBYTECODE, \
SRC := $(NASGEN_SRC) $(ASM_SRC), \
- BIN := $(BUILDTOOLS_OUTPUTDIR)/nasgen_classes, \
- ADD_JAVAC_FLAGS := -Xbootclasspath/p:"$(SUPPORT_OUTPUTDIR)/special_classes/jdk.scripting.nashorn/classes"))
-
-# Nasgen needs nashorn classes
-$(BUILD_NASGEN): $(jdk.scripting.nashorn)
+ BIN := $(BUILDTOOLS_OUTPUTDIR)/nasgen_classes))
NASHORN_CLASSES_DIR := $(JDK_OUTPUTDIR)/modules/jdk.scripting.nashorn
NASGEN_RUN_FILE := $(NASHORN_CLASSES_DIR)/_the.nasgen.run
+ifeq ($(BOOT_JDK_MODULAR), true)
+ NASGEN_OPTIONS := \
+ -cp $(BUILDTOOLS_OUTPUTDIR)/nasgen_classes \
+ -Xpatch:$(BUILDTOOLS_OUTPUTDIR)/nasgen_classes \
+ -XaddExports:$(subst $(SPACE),$(COMMA),$(strip \
+ java.base/jdk.internal.org.objectweb.asm=ALL-UNNAMED \
+ java.base/jdk.internal.org.objectweb.asm.util=ALL-UNNAMED \
+ ))
+else
+ NASGEN_OPTIONS := \
+ -Xbootclasspath/p:$(BUILDTOOLS_OUTPUTDIR)/nasgen_classes
+endif
+
# Copy classes to final classes dir and run nasgen to modify classes in jdk.nashorn.internal.objects package
-$(NASGEN_RUN_FILE): $(BUILD_NASGEN)
+$(NASGEN_RUN_FILE): $(BUILD_NASGEN) $(jdk.scripting.nashorn)
$(ECHO) Running nasgen
$(MKDIR) -p $(@D)
$(RM) -rf $(@D)/jdk $(@D)/netscape
- $(CP) -R -p $(SUPPORT_OUTPUTDIR)/special_classes/jdk.scripting.nashorn/classes/* $(@D)/
- $(FIXPATH) $(JAVA) \
- -Xbootclasspath/p:$(call PathList, $(BUILDTOOLS_OUTPUTDIR)/nasgen_classes \
- $(SUPPORT_OUTPUTDIR)/special_classes/jdk.scripting.nashorn/classes) \
+ $(CP) -R -p $(SUPPORT_OUTPUTDIR)/special_classes/jdk.scripting.nashorn/* $(@D)/
+ $(JAVA) $(NASGEN_OPTIONS) \
jdk.nashorn.internal.tools.nasgen.Main $(@D) jdk.nashorn.internal.objects $(@D)
$(TOUCH) $@
diff --git a/nashorn/make/build-nasgen.xml b/nashorn/make/build-nasgen.xml
index 003201199f4..5c8eccf43e2 100644
--- a/nashorn/make/build-nasgen.xml
+++ b/nashorn/make/build-nasgen.xml
@@ -35,13 +35,11 @@
-
-
-
-
+
+
-
+
diff --git a/nashorn/make/build.xml b/nashorn/make/build.xml
index dff7478f6f1..d48765fefe4 100644
--- a/nashorn/make/build.xml
+++ b/nashorn/make/build.xml
@@ -32,13 +32,10 @@
-
-
+
+
-
-
-
-
+
@@ -136,7 +133,10 @@
-
+
+
+
+
@@ -150,9 +150,8 @@
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
+
-
+
-
-
+
+
-
- ${line.separator}
-
+
+ ${line.separator}
+
-
-
-
-
-
+
+
+
+
+
@@ -204,6 +226,9 @@
+
+
+
@@ -212,35 +237,10 @@
-
- Builds the javafx shell.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
@@ -260,7 +260,7 @@
@@ -304,7 +304,7 @@
-
+
@@ -334,10 +334,11 @@
debug="${javac.debug}"
encoding="${javac.encoding}"
includeantruntime="false" fork="true">
-
+
+
@@ -379,7 +380,11 @@
-grant codeBase "file:/${toString:dist.path}/nashorn.jar" {
+grant codeBase "file:/${basedir}/${dynalink.module.classes.dir}" {
+ permission java.security.AllPermission;
+};
+
+grant codeBase "file:/${basedir}/${nashorn.module.classes.dir}" {
permission java.security.AllPermission;
};
@@ -530,7 +535,6 @@ grant codeBase "file:/${basedir}/test/script/markdown.js" {
-
@@ -553,7 +557,6 @@ grant codeBase "file:/${basedir}/test/script/markdown.js" {
-
@@ -571,7 +574,7 @@ grant codeBase "file:/${basedir}/test/script/markdown.js" {
-
+
@@ -616,7 +619,6 @@ grant codeBase "file:/${basedir}/test/script/markdown.js" {
-
@@ -636,7 +638,6 @@ grant codeBase "file:/${basedir}/test/script/markdown.js" {
-
@@ -655,7 +656,6 @@ grant codeBase "file:/${basedir}/test/script/markdown.js" {
-
@@ -675,7 +675,6 @@ grant codeBase "file:/${basedir}/test/script/markdown.js" {
-
@@ -696,7 +695,6 @@ grant codeBase "file:/${basedir}/test/script/markdown.js" {
-
@@ -715,7 +713,6 @@ grant codeBase "file:/${basedir}/test/script/markdown.js" {
-
@@ -725,7 +722,6 @@ grant codeBase "file:/${basedir}/test/script/markdown.js" {
-
diff --git a/nashorn/make/nbproject/ide-targets.xml b/nashorn/make/nbproject/ide-targets.xml
index 7237f6d4120..503f89a1887 100644
--- a/nashorn/make/nbproject/ide-targets.xml
+++ b/nashorn/make/nbproject/ide-targets.xml
@@ -32,7 +32,7 @@
-
+
diff --git a/nashorn/make/project.properties b/nashorn/make/project.properties
index fbaca210b7e..9b4bdbd2be4 100644
--- a/nashorn/make/project.properties
+++ b/nashorn/make/project.properties
@@ -31,8 +31,8 @@ jdk.jline.src.dir=../jdk/src/jdk.internal.le/share/classes
# source and target levels
build.compiler=modern
-javac.source=1.8
-javac.target=1.8
+javac.source=1.9
+javac.target=1.9
javadoc.option=-tag "implSpec:a:Implementation Requirements:"
@@ -53,6 +53,12 @@ nashorn.shell.tool=jdk.nashorn.tools.Shell
# nasgen tool
nasgen.tool=jdk.nashorn.internal.tools.nasgen.Main
+nasgen.module.imports=\
+
+nasgen.module.imports=\
+ java.base/jdk.internal.org.objectweb.asm=ALL-UNNAMED,\
+ java.base/jdk.internal.org.objectweb.asm.util=ALL-UNNAMED
+
# parallel test runner tool
parallel.test.runner=jdk.nashorn.internal.test.framework.ParallelTestRunner
@@ -70,15 +76,11 @@ build.nooptimistic.test.results.dir=${build.dir}/test/nooptimistic/reports
# This directory is removed when the project is cleaned:
dist.dir=dist
-dist.jar=${dist.dir}/nashorn.jar
+dynalink.jar=${dist.dir}/dynalink.jar
+nashorn.jar=${dist.dir}/nashorn.jar
+jjs.jar=${dist.dir}/jjs.jar
dist.javadoc.dir=${dist.dir}/javadoc
-# nashorn javafx shell
-fxshell.tool = jdk.nashorn.tools.FXShell
-fxshell.classes.dir = ${build.dir}/fxshell/classes
-fxshell.dir = tools/fxshell
-fxshell.jar = ${dist.dir}/nashornfx.jar
-
# configuration for java flight recorder
run.test.jvmargs.jfr=-XX:+UnlockCommercialFeatures -XX:+FlightRecorder -XX:FlightRecorderOptions=defaultrecording=true,disk=true,dumponexit=true,dumponexitpath=${build.dir},stackdepth=128
@@ -121,16 +123,28 @@ testng.listeners=\
javac.debug=true
javac.encoding=ascii
-javac.classpath=\
- ${build.classes.dir}
javac.test.classpath=\
- ${build.classes.dir}${path.separator}\
${build.test.classes.dir}${path.separator}\
${file.reference.testng.jar}${path.separator}\
${file.reference.jcommander.jar}${path.separator}\
${file.reference.bsh.jar}${path.separator}\
${file.reference.snakeyaml.jar}
+test.module.imports=\
+ jdk.scripting.nashorn/jdk.nashorn.internal.ir=ALL-UNNAMED,\
+ jdk.scripting.nashorn/jdk.nashorn.internal.codegen=ALL-UNNAMED,\
+ jdk.scripting.nashorn/jdk.nashorn.internal.parser=ALL-UNNAMED,\
+ jdk.scripting.nashorn/jdk.nashorn.internal.objects=ALL-UNNAMED,\
+ jdk.scripting.nashorn/jdk.nashorn.internal.runtime=ALL-UNNAMED,\
+ jdk.scripting.nashorn/jdk.nashorn.internal.runtime.doubleconv=ALL-UNNAMED,\
+ jdk.scripting.nashorn/jdk.nashorn.internal.runtime.linker=ALL-UNNAMED,\
+ jdk.scripting.nashorn/jdk.nashorn.internal.runtime.events=ALL-UNNAMED,\
+ jdk.scripting.nashorn/jdk.nashorn.internal.runtime.options=ALL-UNNAMED,\
+ jdk.scripting.nashorn/jdk.nashorn.internal.runtime.regexp=ALL-UNNAMED,\
+ jdk.scripting.nashorn/jdk.nashorn.internal.runtime.regexp.joni=ALL-UNNAMED,\
+ jdk.scripting.nashorn/jdk.nashorn.tools=ALL-UNNAMED,\
+ java.base/jdk.internal.org.objectweb.asm=ALL-UNNAMED
+
meta.inf.dir=${nashorn.module.src.dir}/META-INF
run.classpath=\
@@ -298,8 +312,11 @@ run.test.classpath=\
${nashorn.api.tests.jar}
dynalink.module.src.dir=src/jdk.dynalink/share/classes
+dynalink.module.classes.dir=${build.classes.dir}/jdk.dynalink
nashorn.module.src.dir=src/jdk.scripting.nashorn/share/classes
+nashorn.module.classes.dir=${build.classes.dir}/jdk.scripting.nashorn
nashorn.shell.module.src.dir=src/jdk.scripting.nashorn.shell/share/classes
+nashorn.shell.module.classes.dir=${build.classes.dir}/jdk.scripting.nashorn.shell
src.dir=${dynalink.module.src.dir}${path.separator}\
${nashorn.module.src.dir}${path.separator}\
@@ -324,6 +341,8 @@ run.test.user.country=TR
run.test.jvmargs.common=\
-server \
+ -XaddExports:${test.module.imports} \
+ -Xpatch:${build.classes.dir} \
-Dfile.encoding=UTF-8 \
-Duser.language=${run.test.user.language} \
-Duser.country=${run.test.user.country} \
diff --git a/nashorn/samples/test.js b/nashorn/samples/test.js
index 1a7e8061732..dfe4b7b937a 100644
--- a/nashorn/samples/test.js
+++ b/nashorn/samples/test.js
@@ -30,3 +30,5 @@
*/
print("Hello World");
+var System = Java.type("java.lang.System");
+print(System.getProperty("jdk.launcher.patch.0"));
diff --git a/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/DynamicLinkerFactory.java b/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/DynamicLinkerFactory.java
index 215abd406b7..eb724e4c82e 100644
--- a/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/DynamicLinkerFactory.java
+++ b/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/DynamicLinkerFactory.java
@@ -384,7 +384,6 @@ public final class DynamicLinkerFactory {
addClasses(knownLinkerClasses, fallbackLinkers);
final List discovered = discoverAutoLoadLinkers();
-
// Now, concatenate ...
final List linkers =
new ArrayList<>(prioritizedLinkers.size() + discovered.size()
diff --git a/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/beans/CallerSensitiveDynamicMethod.java b/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/beans/CallerSensitiveDynamicMethod.java
index cef183cb063..b855f8ae43c 100644
--- a/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/beans/CallerSensitiveDynamicMethod.java
+++ b/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/beans/CallerSensitiveDynamicMethod.java
@@ -158,13 +158,13 @@ class CallerSensitiveDynamicMethod extends SingleDynamicMethod {
GET_LOOKUP_CONTEXT);
if(target instanceof Method) {
- final MethodHandle mh = Lookup.unreflect(lookup, (Method)target);
+ final MethodHandle mh = Lookup.unreflectCallerSensitive(lookup, (Method)target);
if(Modifier.isStatic(((Member)target).getModifiers())) {
return StaticClassIntrospector.editStaticMethodHandle(mh);
}
return mh;
}
- return StaticClassIntrospector.editConstructorMethodHandle(Lookup.unreflectConstructor(lookup,
+ return StaticClassIntrospector.editConstructorMethodHandle(Lookup.unreflectConstructorCallerSensitive(lookup,
(Constructor>)target));
}
diff --git a/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/beans/CheckRestrictedPackage.java b/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/beans/CheckRestrictedPackage.java
index fe428a74204..2427cc63205 100644
--- a/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/beans/CheckRestrictedPackage.java
+++ b/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/beans/CheckRestrictedPackage.java
@@ -84,6 +84,7 @@
package jdk.dynalink.beans;
import java.lang.reflect.Modifier;
+import java.lang.reflect.Module;
import java.security.AccessControlContext;
import java.security.AccessController;
import java.security.PrivilegedAction;
@@ -106,23 +107,29 @@ class CheckRestrictedPackage {
// Non-public classes are always restricted
return true;
}
- final SecurityManager sm = System.getSecurityManager();
- if(sm == null) {
- // No further restrictions if we don't have a security manager
- return false;
- }
final String name = clazz.getName();
final int i = name.lastIndexOf('.');
if (i == -1) {
// Classes in default package are never restricted
return false;
}
+ final String pkgName = name.substring(0, i);
+ final Module module = clazz.getModule();
+ if (module != null && !module.isExported(pkgName)) {
+ return true;
+ }
+
+ final SecurityManager sm = System.getSecurityManager();
+ if(sm == null) {
+ // No further restrictions if we don't have a security manager
+ return false;
+ }
// Do a package access check from within an access control context with no permissions
try {
AccessController.doPrivileged(new PrivilegedAction() {
@Override
public Void run() {
- sm.checkPackageAccess(name.substring(0, i));
+ sm.checkPackageAccess(pkgName);
return null;
}
}, NO_PERMISSIONS_CONTEXT);
diff --git a/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/linker/support/Lookup.java b/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/linker/support/Lookup.java
index 4852cc018ec..adafcaaf018 100644
--- a/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/linker/support/Lookup.java
+++ b/nashorn/src/jdk.dynalink/share/classes/jdk/dynalink/linker/support/Lookup.java
@@ -87,8 +87,11 @@ import java.lang.invoke.MethodHandle;
import java.lang.invoke.MethodHandles;
import java.lang.invoke.MethodType;
import java.lang.reflect.Constructor;
+import java.lang.reflect.Executable;
import java.lang.reflect.Field;
+import java.lang.reflect.Module;
import java.lang.reflect.Method;
+import jdk.internal.module.Modules;
/**
* A wrapper around {@link java.lang.invoke.MethodHandles.Lookup} that masks
@@ -127,6 +130,42 @@ public final class Lookup {
return unreflect(lookup, m);
}
+ private static boolean addModuleRead(final MethodHandles.Lookup lookup, final Executable e) {
+ // may be module read missing from a script class!
+ final Class> declClass = e.getDeclaringClass();
+ final Module from = lookup.lookupClass().getModule();
+ final Module to = declClass.getModule();
+ if (from != null && to != null) {
+ Modules.addReads(from, to);
+ return true;
+ }
+
+ return false;
+ }
+
+ /**
+ * Performs a {@link java.lang.invoke.MethodHandles.Lookup#unreflect(Method)}, of a caller sensitive method
+ * converting any encountered {@link IllegalAccessException} into an {@link IllegalAccessError}.
+ *
+ * @param lookup the lookup used to unreflect
+ * @param m the method to unreflect
+ * @return the unreflected method handle.
+ */
+ public static MethodHandle unreflectCallerSensitive(final MethodHandles.Lookup lookup, final Method m) {
+ try {
+ return unreflect(lookup, m);
+ } catch (final IllegalAccessError iae) {
+ if (addModuleRead(lookup, m)) {
+ try {
+ return unreflect(lookup, m);
+ } catch (final IllegalAccessError e2) {
+ // fall through and throw original error as cause
+ }
+ }
+ throw iae;
+ }
+ }
+
/**
* Performs a {@link java.lang.invoke.MethodHandles.Lookup#unreflect(Method)},
* converting any encountered {@link IllegalAccessException} into an
@@ -227,6 +266,29 @@ public final class Lookup {
return unreflectConstructor(lookup, c);
}
+ /**
+ * Performs a caller sensitive {@link java.lang.invoke.MethodHandles.Lookup#unreflectConstructor(Constructor)}, converting any
+ * encountered {@link IllegalAccessException} into an {@link IllegalAccessError}.
+ *
+ * @param lookup the lookup used to unreflect
+ * @param c the constructor to unreflect
+ * @return the unreflected constructor handle.
+ */
+ public static MethodHandle unreflectConstructorCallerSensitive(final MethodHandles.Lookup lookup, final Constructor> c) {
+ try {
+ return unreflectConstructor(lookup, c);
+ } catch (final IllegalAccessError iae) {
+ if (addModuleRead(lookup, c)) {
+ try {
+ return unreflectConstructor(lookup, c);
+ } catch (final IllegalAccessError e2) {
+ // fall through and throw original error as cause
+ }
+ }
+ throw iae;
+ }
+ }
+
/**
* Performs a {@link java.lang.invoke.MethodHandles.Lookup#unreflectConstructor(Constructor)},
* converting any encountered {@link IllegalAccessException} into an
diff --git a/nashorn/src/jdk.dynalink/share/classes/module-info.java b/nashorn/src/jdk.dynalink/share/classes/module-info.java
new file mode 100644
index 00000000000..b9abdc3dbd1
--- /dev/null
+++ b/nashorn/src/jdk.dynalink/share/classes/module-info.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright (c) 2015, 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. Oracle designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Oracle in the LICENSE file that accompanied this code.
+ *
+ * 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.
+ */
+
+module jdk.dynalink {
+ requires java.logging;
+
+ exports jdk.dynalink;
+ exports jdk.dynalink.beans;
+ exports jdk.dynalink.linker;
+ exports jdk.dynalink.linker.support;
+ exports jdk.dynalink.support;
+
+ uses jdk.dynalink.linker.GuardingDynamicLinkerExporter;
+}
+
diff --git a/nashorn/src/jdk.scripting.nashorn.shell/share/classes/module-info.java b/nashorn/src/jdk.scripting.nashorn.shell/share/classes/module-info.java
new file mode 100644
index 00000000000..953ca18aada
--- /dev/null
+++ b/nashorn/src/jdk.scripting.nashorn.shell/share/classes/module-info.java
@@ -0,0 +1,32 @@
+/*
+ * Copyright (c) 2014, 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. Oracle designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Oracle in the LICENSE file that accompanied this code.
+ *
+ * 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.
+ */
+
+module jdk.scripting.nashorn.shell {
+ requires java.desktop;
+ requires java.compiler;
+ requires jdk.scripting.nashorn;
+ requires jdk.internal.le;
+}
+
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/META-INF/MANIFEST.MF b/nashorn/src/jdk.scripting.nashorn/share/classes/META-INF/MANIFEST.MF
deleted file mode 100644
index b61190e5ba9..00000000000
--- a/nashorn/src/jdk.scripting.nashorn/share/classes/META-INF/MANIFEST.MF
+++ /dev/null
@@ -1,5 +0,0 @@
-Manifest-Version: 1.0
-Main-Class: jdk.nashorn.tools.Shell
-
-Name: jdk/nashorn/
-Implementation-Vendor: Oracle Corporation
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/META-INF/services/javax.script.ScriptEngineFactory b/nashorn/src/jdk.scripting.nashorn/share/classes/META-INF/services/javax.script.ScriptEngineFactory
deleted file mode 100644
index 60a8f56b8b5..00000000000
--- a/nashorn/src/jdk.scripting.nashorn/share/classes/META-INF/services/javax.script.ScriptEngineFactory
+++ /dev/null
@@ -1,25 +0,0 @@
-#
-# Copyright (c) 2010, 2013, 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. Oracle designates this
-# particular file as subject to the "Classpath" exception as provided
-# by Oracle in the LICENSE file that accompanied this code.
-#
-# 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.nashorn.api.scripting.NashornScriptEngineFactory
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/OptimisticTypesPersistence.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/OptimisticTypesPersistence.java
index dfaecb2411b..0301f46dfe6 100644
--- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/OptimisticTypesPersistence.java
+++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/OptimisticTypesPersistence.java
@@ -353,6 +353,8 @@ public final class OptimisticTypesPersistence {
}
}
+ private static final String ANCHOR_PROPS = "anchor.properties";
+
/**
* In order to ensure that changes in Nashorn code don't cause corruption in the data, we'll create a
* per-code-version directory. Normally, this will create the SHA-1 digest of the nashorn.jar. In case the classpath
@@ -368,7 +370,7 @@ public final class OptimisticTypesPersistence {
// getResource("OptimisticTypesPersistence.class") but behavior of getResource with regard to its willingness
// to hand out URLs to .class files is also unspecified. Therefore, the most robust way to obtain an URL to our
// package is to have a small non-class anchor file and start out from its URL.
- final URL url = OptimisticTypesPersistence.class.getResource("anchor.properties");
+ final URL url = OptimisticTypesPersistence.class.getResource(ANCHOR_PROPS);
final String protocol = url.getProtocol();
if (protocol.equals("jar")) {
// Normal deployment: nashorn.jar
@@ -391,7 +393,7 @@ public final class OptimisticTypesPersistence {
final String fileStr = url.getFile();
final String className = OptimisticTypesPersistence.class.getName();
final int packageNameLen = className.lastIndexOf('.');
- final String dirStr = fileStr.substring(0, fileStr.length() - packageNameLen - 1);
+ final String dirStr = fileStr.substring(0, fileStr.length() - packageNameLen - 1 - ANCHOR_PROPS.length());
final File dir = new File(dirStr);
return "dev-" + new SimpleDateFormat("yyyyMMdd-HHmmss").format(new Date(getLastModifiedClassFile(
dir, 0L)));
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Context.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Context.java
index cbc4d2eae7f..64a67d89eb1 100644
--- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Context.java
+++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Context.java
@@ -36,6 +36,7 @@ import static jdk.nashorn.internal.runtime.ScriptRuntime.UNDEFINED;
import static jdk.nashorn.internal.runtime.Source.sourceFor;
import java.io.File;
+import java.io.InputStream;
import java.io.IOException;
import java.io.PrintWriter;
import java.lang.invoke.MethodHandle;
@@ -490,7 +491,7 @@ public final class Context {
private static final ConcurrentMap> structureClasses = new ConcurrentHashMap<>();
/*package-private*/ @SuppressWarnings("static-method")
- ClassLoader getSharedLoader() {
+ StructureLoader getSharedLoader() {
return sharedLoader;
}
@@ -842,8 +843,8 @@ public final class Context {
@Override
public Source run() {
try {
- final URL resURL = Context.class.getResource(resource);
- return resURL != null ? sourceFor(srcStr, resURL) : null;
+ final InputStream resStream = Context.class.getResourceAsStream(resource);
+ return resStream != null ? sourceFor(srcStr, Source.readFully(resStream)) : null;
} catch (final IOException exp) {
return null;
}
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/NashornLoader.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/NashornLoader.java
index e307123242d..78256cc7185 100644
--- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/NashornLoader.java
+++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/NashornLoader.java
@@ -30,25 +30,40 @@ import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLClassLoader;
+import java.lang.reflect.Module;
import java.security.CodeSource;
import java.security.Permission;
import java.security.PermissionCollection;
import java.security.Permissions;
import java.security.SecureClassLoader;
+import java.util.HashSet;
+import java.util.Set;
+import jdk.internal.module.Modules;
/**
* Superclass for Nashorn class loader classes.
*/
abstract class NashornLoader extends SecureClassLoader {
- private static final String OBJECTS_PKG = "jdk.nashorn.internal.objects";
- private static final String RUNTIME_PKG = "jdk.nashorn.internal.runtime";
- private static final String RUNTIME_ARRAYS_PKG = "jdk.nashorn.internal.runtime.arrays";
- private static final String RUNTIME_LINKER_PKG = "jdk.nashorn.internal.runtime.linker";
- private static final String SCRIPTS_PKG = "jdk.nashorn.internal.scripts";
+ protected static final String OBJECTS_PKG = "jdk.nashorn.internal.objects";
+ protected static final String RUNTIME_PKG = "jdk.nashorn.internal.runtime";
+ protected static final String RUNTIME_ARRAYS_PKG = "jdk.nashorn.internal.runtime.arrays";
+ protected static final String RUNTIME_LINKER_PKG = "jdk.nashorn.internal.runtime.linker";
+ protected static final String SCRIPTS_PKG = "jdk.nashorn.internal.scripts";
+ protected static final String OBJECTS_PKG_INTERNAL = "jdk/nashorn/internal/objects";
+ protected static final String RUNTIME_PKG_INTERNAL = "jdk/nashorn/internal/runtime";
+ protected static final String RUNTIME_ARRAYS_PKG_INTERNAL = "jdk/nashorn/internal/runtime/arrays";
+ protected static final String RUNTIME_LINKER_PKG_INTERNAL = "jdk/nashorn/internal/runtime/linker";
+ protected static final String SCRIPTS_PKG_INTERNAL = "jdk/nashorn/internal/scripts";
+
+ protected static final Module nashornModule = NashornLoader.class.getModule();
private static final Permission[] SCRIPT_PERMISSIONS;
+ private static final Set scriptsPkgSet = new HashSet<>();
+
static {
+ scriptsPkgSet.add(SCRIPTS_PKG);
+
/*
* Generated classes get access to runtime, runtime.linker, objects, scripts packages.
* Note that the actual scripts can not access these because Java.type, Packages
@@ -69,6 +84,22 @@ abstract class NashornLoader extends SecureClassLoader {
super(parent);
}
+ protected static Module defineModule(final String moduleName, final ClassLoader loader) {
+ return Modules.defineModule(loader, moduleName, scriptsPkgSet);
+ }
+
+ protected static void addReadsModule(final Module from, final Module to) {
+ Modules.addReads(from, to);
+ }
+
+ protected static void addModuleExports(final Module from, final String pkg, final Module to) {
+ if (to == null) {
+ Modules.addExportsToAll(from, pkg);
+ } else {
+ Modules.addExports(from, pkg, to);
+ }
+ }
+
protected static void checkPackageAccess(final String name) {
final int i = name.lastIndexOf('.');
if (i != -1) {
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/ScriptLoader.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/ScriptLoader.java
index 3b66c99815f..79028705238 100644
--- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/ScriptLoader.java
+++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/ScriptLoader.java
@@ -25,6 +25,7 @@
package jdk.nashorn.internal.runtime;
+import java.lang.reflect.Module;
import java.security.CodeSource;
import java.util.Objects;
@@ -35,6 +36,8 @@ import java.util.Objects;
final class ScriptLoader extends NashornLoader {
private static final String NASHORN_PKG_PREFIX = "jdk.nashorn.internal.";
+ private volatile boolean structureAccessAdded;
+ private final Module scriptModule;
private final Context context;
/*package-private*/ Context getContext() {
@@ -47,13 +50,39 @@ final class ScriptLoader extends NashornLoader {
ScriptLoader(final ClassLoader parent, final Context context) {
super(parent);
this.context = context;
+
+ // new scripts module, it's specific exports and read-edges
+ scriptModule = defineModule("jdk.scripting.nashorn.scripts", this);
+ addModuleExports(scriptModule, SCRIPTS_PKG, nashornModule);
+ addReadsModule(scriptModule, nashornModule);
+ addReadsModule(scriptModule, Object.class.getModule());
+
+ // specific exports from nashorn to new scripts module
+ nashornModule.addExports(OBJECTS_PKG, scriptModule);
+ nashornModule.addExports(RUNTIME_PKG, scriptModule);
+ nashornModule.addExports(RUNTIME_ARRAYS_PKG, scriptModule);
+ nashornModule.addExports(RUNTIME_LINKER_PKG, scriptModule);
+ nashornModule.addExports(SCRIPTS_PKG, scriptModule);
+
+ // nashorn needs to read scripts module methods,fields
+ nashornModule.addReads(scriptModule);
}
@Override
protected Class> loadClass(final String name, final boolean resolve) throws ClassNotFoundException {
checkPackageAccess(name);
if (name.startsWith(NASHORN_PKG_PREFIX)) {
- return context.getSharedLoader().loadClass(name);
+ final StructureLoader sharedCl = context.getSharedLoader();
+ final Class> cl = sharedCl.loadClass(name);
+ if (! structureAccessAdded) {
+ if (cl.getClassLoader() == sharedCl) {
+ structureAccessAdded = true;
+ final Module structModule = sharedCl.getModule();
+ addModuleExports(structModule, SCRIPTS_PKG, scriptModule);
+ addReadsModule(scriptModule, structModule);
+ }
+ }
+ return cl;
}
return super.loadClass(name, resolve);
}
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Source.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Source.java
index 99a4bf2de6c..2331ce12bce 100644
--- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Source.java
+++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Source.java
@@ -922,7 +922,7 @@ public final class Source implements Loggable {
return (cs != null) ? new String(readBytes(is), cs).toCharArray() : readFully(is);
}
- private static char[] readFully(final InputStream is) throws IOException {
+ public static char[] readFully(final InputStream is) throws IOException {
return byteToCharArray(readBytes(is));
}
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/StructureLoader.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/StructureLoader.java
index 8324730a264..b179c257be4 100644
--- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/StructureLoader.java
+++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/StructureLoader.java
@@ -30,6 +30,7 @@ import static jdk.nashorn.internal.codegen.Compiler.binaryName;
import static jdk.nashorn.internal.codegen.CompilerConstants.JS_OBJECT_DUAL_FIELD_PREFIX;
import static jdk.nashorn.internal.codegen.CompilerConstants.JS_OBJECT_SINGLE_FIELD_PREFIX;
+import java.lang.reflect.Module;
import java.security.ProtectionDomain;
import jdk.nashorn.internal.codegen.ObjectClassGenerator;
@@ -40,11 +41,26 @@ final class StructureLoader extends NashornLoader {
private static final String SINGLE_FIELD_PREFIX = binaryName(SCRIPTS_PACKAGE) + '.' + JS_OBJECT_SINGLE_FIELD_PREFIX.symbolName();
private static final String DUAL_FIELD_PREFIX = binaryName(SCRIPTS_PACKAGE) + '.' + JS_OBJECT_DUAL_FIELD_PREFIX.symbolName();
+ private final Module structuresModule;
+
/**
* Constructor.
*/
StructureLoader(final ClassLoader parent) {
super(parent);
+
+ // new structures module, it's exports, read edges
+ structuresModule = defineModule("jdk.scripting.nashorn.structures", this);
+ addModuleExports(structuresModule, SCRIPTS_PKG, nashornModule);
+ addReadsModule(structuresModule, nashornModule);
+ addReadsModule(structuresModule, Object.class.getModule());
+
+ // specific exports from nashorn to the structures module
+ nashornModule.addExports(SCRIPTS_PKG, structuresModule);
+ nashornModule.addExports(RUNTIME_PKG, structuresModule);
+
+ // nashorn has to read fields from classes of the new module
+ nashornModule.addReads(structuresModule);
}
/**
@@ -74,6 +90,10 @@ final class StructureLoader extends NashornLoader {
return isDualFieldStructure(name) || isSingleFieldStructure(name);
}
+ protected Module getModule() {
+ return structuresModule;
+ }
+
@Override
protected Class> findClass(final String name) throws ClassNotFoundException {
if (isDualFieldStructure(name)) {
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/JavaAdapterBytecodeGenerator.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/JavaAdapterBytecodeGenerator.java
index ba82e64af9f..54d2e12620f 100644
--- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/JavaAdapterBytecodeGenerator.java
+++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/JavaAdapterBytecodeGenerator.java
@@ -51,6 +51,7 @@ import java.lang.reflect.AccessibleObject;
import java.lang.reflect.Constructor;
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
+import java.lang.reflect.Module;
import java.security.AccessControlContext;
import java.security.AccessController;
import java.security.PrivilegedAction;
@@ -197,12 +198,8 @@ final class JavaAdapterBytecodeGenerator {
private static final String GET_METHOD_PROPERTY_METHOD_DESCRIPTOR = Type.getMethodDescriptor(OBJECT_TYPE, SCRIPT_OBJECT_TYPE);
private static final String VOID_METHOD_DESCRIPTOR = Type.getMethodDescriptor(Type.VOID_TYPE);
- // Package used when the adapter can't be defined in the adaptee's package (either because it's sealed, or because
- // it's a java.* package.
- private static final String ADAPTER_PACKAGE_PREFIX = "jdk/nashorn/javaadapters/";
- // Class name suffix used to append to the adaptee class name, when it can be defined in the adaptee's package.
- private static final String ADAPTER_CLASS_NAME_SUFFIX = "$$NashornJavaAdapter";
- private static final String JAVA_PACKAGE_PREFIX = "java/";
+ static final String ADAPTER_PACKAGE_INTERNAL = "jdk/nashorn/javaadapters/";
+ static final String ADAPTER_PACKAGE = "jdk.nashorn.javaadapters";
private static final int MAX_GENERATED_TYPE_NAME_LENGTH = 255;
// Method name prefix for invoking super-methods
@@ -237,6 +234,7 @@ final class JavaAdapterBytecodeGenerator {
private final Set methodInfos = new HashSet<>();
private final boolean autoConvertibleFromFunction;
private boolean hasExplicitFinalizer = false;
+ private final Set accessedModules = new HashSet<>();
private final ClassWriter cw;
@@ -300,7 +298,7 @@ final class JavaAdapterBytecodeGenerator {
}
JavaAdapterClassLoader createAdapterClassLoader() {
- return new JavaAdapterClassLoader(generatedClassName, cw.toByteArray());
+ return new JavaAdapterClassLoader(generatedClassName, cw.toByteArray(), accessedModules);
}
boolean isAutoConvertibleFromFunction() {
@@ -314,12 +312,7 @@ final class JavaAdapterBytecodeGenerator {
final Package pkg = namingType.getPackage();
final String namingTypeName = Type.getInternalName(namingType);
final StringBuilder buf = new StringBuilder();
- if (namingTypeName.startsWith(JAVA_PACKAGE_PREFIX) || pkg == null || pkg.isSealed()) {
- // Can't define new classes in java.* packages
- buf.append(ADAPTER_PACKAGE_PREFIX).append(namingTypeName);
- } else {
- buf.append(namingTypeName).append(ADAPTER_CLASS_NAME_SUFFIX);
- }
+ buf.append(ADAPTER_PACKAGE_INTERNAL).append(namingTypeName.replace('/', '_'));
final Iterator> it = interfaces.iterator();
if(superType == Object.class && it.hasNext()) {
it.next(); // Skip first interface, it was used to primarily name the adapter
@@ -359,7 +352,7 @@ final class JavaAdapterBytecodeGenerator {
// If the class is a SAM, allow having ScriptFunction passed as class overrides
mv.dup();
mv.instanceOf(SCRIPT_FUNCTION_TYPE);
- mv.dup();
+ mv.dup();
mv.putstatic(generatedClassName, IS_FUNCTION_FIELD_NAME, BOOLEAN_TYPE_DESCRIPTOR);
final Label notFunction = new Label();
mv.ifeq(notFunction);
@@ -379,9 +372,9 @@ final class JavaAdapterBytecodeGenerator {
private void emitInitCallThis(final InstructionAdapter mv) {
loadField(mv, GLOBAL_FIELD_NAME, SCRIPT_OBJECT_TYPE_DESCRIPTOR);
GET_CALL_THIS.invoke(mv);
- if(classOverride) {
+ if(classOverride) {
mv.putstatic(generatedClassName, CALL_THIS_FIELD_NAME, OBJECT_TYPE_DESCRIPTOR);
- } else {
+ } else {
// It is presumed ALOAD 0 was already executed
mv.putfield(generatedClassName, CALL_THIS_FIELD_NAME, OBJECT_TYPE_DESCRIPTOR);
}
@@ -404,6 +397,14 @@ final class JavaAdapterBytecodeGenerator {
}
private boolean generateConstructors(final Constructor> ctor) {
+ for (final Class> pt : ctor.getParameterTypes()) {
+ if (pt.isPrimitive()) continue;
+ final Module ptMod = pt.getModule();
+ if (ptMod != null) {
+ accessedModules.add(ptMod);
+ }
+ }
+
if(classOverride) {
// Generate a constructor that just delegates to ctor. This is used with class-level overrides, when we want
// to create instances without further per-instance overrides.
@@ -411,16 +412,16 @@ final class JavaAdapterBytecodeGenerator {
return false;
}
- // Generate a constructor that delegates to ctor, but takes an additional ScriptObject parameter at the
- // beginning of its parameter list.
- generateOverridingConstructor(ctor, false);
+ // Generate a constructor that delegates to ctor, but takes an additional ScriptObject parameter at the
+ // beginning of its parameter list.
+ generateOverridingConstructor(ctor, false);
if (samName == null) {
return false;
- }
- // If all our abstract methods have a single name, generate an additional constructor, one that takes a
- // ScriptFunction as its first parameter and assigns it as the implementation for all abstract methods.
- generateOverridingConstructor(ctor, true);
+ }
+ // If all our abstract methods have a single name, generate an additional constructor, one that takes a
+ // ScriptFunction as its first parameter and assigns it as the implementation for all abstract methods.
+ generateOverridingConstructor(ctor, true);
// If the original type only has a single abstract method name, as well as a default ctor, then it can
// be automatically converted from JS function.
return ctor.getParameterTypes().length == 0;
@@ -499,7 +500,7 @@ final class JavaAdapterBytecodeGenerator {
mv.iconst(1);
mv.putfield(generatedClassName, IS_FUNCTION_FIELD_NAME, BOOLEAN_TYPE_DESCRIPTOR);
- mv.visitVarInsn(ALOAD, 0);
+ mv.visitVarInsn(ALOAD, 0);
mv.visitVarInsn(ALOAD, extraArgOffset);
emitInitCallThis(mv);
}
@@ -668,7 +669,7 @@ final class JavaAdapterBytecodeGenerator {
// stack: [callThis, delegate]
mv.goTo(callCallee);
mv.visitLabel(notFunction);
- } else {
+ } else {
// If it's not a SAM method, and the delegate is a function,
// it'll fall back to default behavior
mv.ifne(defaultBehavior);
@@ -808,7 +809,7 @@ final class JavaAdapterBytecodeGenerator {
if (isVarArgCall) {
// Variable arity calls are always (Object callee, Object this, Object[] params)
callParamTypes = new Class>[] { Object.class, Object.class, Object[].class };
- } else {
+ } else {
// Adjust invocation type signature for conversions we instituted in
// convertParam; also, byte and short get passed as ints.
final Class>[] origParamTypes = type.parameterArray();
@@ -858,13 +859,13 @@ final class JavaAdapterBytecodeGenerator {
private void loadField(final InstructionAdapter mv, final String name, final String desc) {
- if(classOverride) {
+ if(classOverride) {
mv.getstatic(generatedClassName, name, desc);
- } else {
- mv.visitVarInsn(ALOAD, 0);
+ } else {
+ mv.visitVarInsn(ALOAD, 0);
mv.getfield(generatedClassName, name, desc);
- }
- }
+ }
+ }
private static void convertReturnValue(final InstructionAdapter mv, final Class> origReturnType) {
if (origReturnType == void.class) {
@@ -1082,6 +1083,11 @@ final class JavaAdapterBytecodeGenerator {
*/
private void gatherMethods(final Class> type) throws AdaptationException {
if (Modifier.isPublic(type.getModifiers())) {
+ final Module module = type.getModule();
+ if (module != null) {
+ accessedModules.add(module);
+ }
+
final Method[] typeMethods = type.isInterface() ? type.getMethods() : type.getDeclaredMethods();
for (final Method typeMethod: typeMethods) {
@@ -1106,12 +1112,26 @@ final class JavaAdapterBytecodeGenerator {
continue;
}
+ for (final Class> pt : typeMethod.getParameterTypes()) {
+ if (pt.isPrimitive()) continue;
+ final Module ptMod = pt.getModule();
+ if (ptMod != null) {
+ accessedModules.add(ptMod);
+ }
+ }
+
+ final Class> rt = typeMethod.getReturnType();
+ if (!rt.isPrimitive()) {
+ final Module rtMod = rt.getModule();
+ if (rtMod != null) accessedModules.add(rtMod);
+ }
+
final MethodInfo mi = new MethodInfo(typeMethod);
if (Modifier.isFinal(m) || isCallerSensitive(typeMethod)) {
finalMethods.add(mi);
} else if (!finalMethods.contains(mi) && methodInfos.add(mi) && Modifier.isAbstract(m)) {
- abstractMethodNames.add(mi.getName());
- }
+ abstractMethodNames.add(mi.getName());
+ }
}
}
}
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/JavaAdapterClassLoader.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/JavaAdapterClassLoader.java
index 6c61607aa78..5498bed1b86 100644
--- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/JavaAdapterClassLoader.java
+++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/JavaAdapterClassLoader.java
@@ -25,6 +25,7 @@
package jdk.nashorn.internal.runtime.linker;
+import java.lang.reflect.Module;
import java.security.AccessControlContext;
import java.security.AccessController;
import java.security.PrivilegedAction;
@@ -34,12 +35,14 @@ import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.HashSet;
+import java.util.Set;
import jdk.dynalink.beans.StaticClass;
import jdk.nashorn.internal.codegen.DumpBytecode;
import jdk.nashorn.internal.runtime.Context;
import jdk.nashorn.internal.runtime.JSType;
import jdk.nashorn.internal.runtime.ScriptFunction;
import jdk.nashorn.internal.runtime.ScriptObject;
+import jdk.internal.module.Modules;
/**
* This class encapsulates the bytecode of the adapter class and can be used to load it into the JVM as an actual Class.
@@ -49,6 +52,12 @@ import jdk.nashorn.internal.runtime.ScriptObject;
* class are normally created by {@code JavaAdapterBytecodeGenerator}.
*/
final class JavaAdapterClassLoader {
+ private static final Module nashornModule = JavaAdapterClassLoader.class.getModule();
+ private static final Set adapterPkgs = new HashSet<>();
+ static {
+ adapterPkgs.add(JavaAdapterBytecodeGenerator.ADAPTER_PACKAGE);
+ }
+
private static final AccessControlContext CREATE_LOADER_ACC_CTXT = ClassAndLoader.createPermAccCtxt("createClassLoader");
private static final AccessControlContext GET_CONTEXT_ACC_CTXT = ClassAndLoader.createPermAccCtxt(Context.NASHORN_GET_CONTEXT);
private static final Collection VISIBLE_INTERNAL_CLASS_NAMES = Collections.unmodifiableCollection(new HashSet<>(
@@ -56,10 +65,12 @@ final class JavaAdapterClassLoader {
private final String className;
private final byte[] classBytes;
+ private final Set accessedModules;
- JavaAdapterClassLoader(final String className, final byte[] classBytes) {
+ JavaAdapterClassLoader(final String className, final byte[] classBytes, final Set accessedModules) {
this.className = className.replace('/', '.');
this.classBytes = classBytes;
+ this.accessedModules = accessedModules;
}
/**
@@ -82,6 +93,14 @@ final class JavaAdapterClassLoader {
}, CREATE_LOADER_ACC_CTXT);
}
+ private static void addExports(final Module from, final String pkg, final Module to) {
+ if (to == null) {
+ Modules.addExportsToAll(from, pkg);
+ } else {
+ Modules.addExports(from, pkg, to);
+ }
+ }
+
// Note that the adapter class is created in the protection domain of the class/interface being
// extended/implemented, and only the privileged global setter action class is generated in the protection domain
// of Nashorn itself. Also note that the creation and loading of the global setter is deferred until it is
@@ -93,6 +112,26 @@ final class JavaAdapterClassLoader {
return new SecureClassLoader(parentLoader) {
private final ClassLoader myLoader = getClass().getClassLoader();
+ // new adapter module
+ private final Module adapterModule = Modules.defineModule(this, "jdk.scripting.nashorn.javaadapters", adapterPkgs);
+
+ {
+ // new adapter module exports and read-edges
+ addExports(adapterModule, JavaAdapterBytecodeGenerator.ADAPTER_PACKAGE, null);
+ Modules.addReads(adapterModule, nashornModule);
+ Modules.addReads(adapterModule, Object.class.getModule());
+ for (Module mod : accessedModules) {
+ Modules.addReads(adapterModule, mod);
+ }
+
+ // specific exports from nashorn to the new adapter module
+ nashornModule.addExports("jdk.nashorn.internal.runtime", adapterModule);
+ nashornModule.addExports("jdk.nashorn.internal.runtime.linker", adapterModule);
+
+ // nashorn should be be able to read methods of classes loaded in adapter module
+ nashornModule.addReads(adapterModule);
+ }
+
@Override
public Class> loadClass(final String name, final boolean resolve) throws ClassNotFoundException {
try {
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/JavaAdapterServices.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/JavaAdapterServices.java
index 8dc490ca268..19c6d32b337 100644
--- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/JavaAdapterServices.java
+++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/JavaAdapterServices.java
@@ -228,7 +228,7 @@ public final class JavaAdapterServices {
});
try {
- return MethodHandles.lookup().findStatic(Class.forName(className, true, loader), "invoke",
+ return MethodHandles.publicLookup().findStatic(Class.forName(className, true, loader), "invoke",
MethodType.methodType(void.class, MethodHandle.class, Object.class));
} catch(final ReflectiveOperationException e) {
throw new AssertionError(e.getMessage(), e);
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/NashornStaticClassLinker.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/NashornStaticClassLinker.java
index 8201aa631cf..60c44c68449 100644
--- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/NashornStaticClassLinker.java
+++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/NashornStaticClassLinker.java
@@ -25,7 +25,9 @@
package jdk.nashorn.internal.runtime.linker;
+import java.lang.invoke.MethodHandles;
import java.lang.reflect.Modifier;
+import jdk.internal.module.Modules;
import jdk.dynalink.CallSiteDescriptor;
import jdk.dynalink.NamedOperation;
import jdk.dynalink.StandardOperation;
@@ -87,8 +89,11 @@ final class NashornStaticClassLinker implements TypeBasedGuardingDynamicLinker {
if (NashornLinker.isAbstractClass(receiverClass)) {
// Change this link request into a link request on the adapter class.
final Object[] args = request.getArguments();
- args[0] = JavaAdapterFactory.getAdapterClassFor(new Class>[] { receiverClass }, null,
- NashornCallSiteDescriptor.getLookupInternal(request.getCallSiteDescriptor()));
+ final MethodHandles.Lookup lookup =
+ NashornCallSiteDescriptor.getLookupInternal(request.getCallSiteDescriptor());
+
+ args[0] = JavaAdapterFactory.getAdapterClassFor(new Class>[] { receiverClass }, null, lookup);
+ Modules.addReads(lookup.lookupClass().getModule(), ((StaticClass)args[0]).getRepresentedClass().getModule());
final LinkRequest adapterRequest = request.replaceArguments(request.getCallSiteDescriptor(), args);
final GuardedInvocation gi = checkNullConstructor(delegate(linkerServices, adapterRequest), receiverClass);
// Finally, modify the guard to test for the original abstract class.
diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/module-info.java b/nashorn/src/jdk.scripting.nashorn/share/classes/module-info.java
new file mode 100644
index 00000000000..fbf83d15bd9
--- /dev/null
+++ b/nashorn/src/jdk.scripting.nashorn/share/classes/module-info.java
@@ -0,0 +1,43 @@
+/*
+ * Copyright (c) 2014, 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. Oracle designates this
+ * particular file as subject to the "Classpath" exception as provided
+ * by Oracle in the LICENSE file that accompanied this code.
+ *
+ * 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.
+ */
+
+module jdk.scripting.nashorn {
+ requires java.logging;
+ requires public java.scripting;
+ requires jdk.dynalink;
+
+ exports jdk.nashorn.api.scripting;
+ exports jdk.nashorn.api.tree;
+
+ exports jdk.nashorn.internal.runtime to
+ jdk.scripting.nashorn.shell;
+ exports jdk.nashorn.internal.objects to
+ jdk.scripting.nashorn.shell;
+ exports jdk.nashorn.tools to
+ jdk.scripting.nashorn.shell;
+
+ provides javax.script.ScriptEngineFactory with jdk.nashorn.api.scripting.NashornScriptEngineFactory;
+}
+
diff --git a/nashorn/test/TEST.ROOT b/nashorn/test/TEST.ROOT
index ad4b96f4f26..bbdb534406f 100644
--- a/nashorn/test/TEST.ROOT
+++ b/nashorn/test/TEST.ROOT
@@ -8,4 +8,4 @@ keys=intermittent randomness
groups=TEST.groups
# Minimum jtreg version
-requiredVersion=4.1 b12
+requiredVersion=4.2 b01
diff --git a/nashorn/test/script/currently-failing/JDK-8055034.js b/nashorn/test/script/currently-failing/JDK-8055034.js
index 3212203722f..0f905156b17 100644
--- a/nashorn/test/script/currently-failing/JDK-8055034.js
+++ b/nashorn/test/script/currently-failing/JDK-8055034.js
@@ -51,7 +51,7 @@ if (! new File(jjsCmd).isFile()) {
jjsCmd = javahome + "/bin/jjs";
jjsCmd = jjsCmd.toString().replace(/\//g, File.separator);
}
-jjsCmd += " -J-Xbootclasspath/p:" + nashornJar;
+jjsCmd += " -J-Xpatch:" + nashornJar;
$ENV.PWD=System.getProperty("user.dir") // to avoid RE on Cygwin
$EXEC(jjsCmd, "var x = Object.create(null);\nx;\nprint('PASSED');\nexit(0)");
diff --git a/nashorn/test/script/nosecurity/JDK-8044798.js b/nashorn/test/script/nosecurity/JDK-8044798.js
index cc2ef835273..dcf17969944 100644
--- a/nashorn/test/script/nosecurity/JDK-8044798.js
+++ b/nashorn/test/script/nosecurity/JDK-8044798.js
@@ -27,7 +27,6 @@
* @test
* @option -Dnashorn.mirror.always=false
* @fork
- * @run
*/
// basic API exercise checks
@@ -120,18 +119,25 @@ printValue(this);
var Source = Java.type("jdk.nashorn.internal.runtime.Source");
var Context = Java.type("jdk.nashorn.internal.runtime.Context");
+var ThrowErrorManager = Java.type("jdk.nashorn.internal.runtime.Context.ThrowErrorManager");
+var contextCls = java.lang.Class.forName("jdk.nashorn.internal.runtime.Context");
var sourceCls = Source.class;
var errorMgrCls = Java.type("jdk.nashorn.internal.runtime.ErrorManager").class;
var booleanCls = Java.type("java.lang.Boolean").TYPE;
+var stringCls = Java.type("java.lang.String").class;
// private compile method of Context class
-var compileMethod = Context.class.getDeclaredMethod("compile",
+var compileMethod = contextCls.getDeclaredMethod("compile",
sourceCls, errorMgrCls, booleanCls, booleanCls);
compileMethod.accessible = true;
-var scriptCls = compileMethod.invoke(Context.context,
- Source.sourceFor("test", "print('hello')"),
- new Context.ThrowErrorManager(), false, false);
+var getContextMethod = contextCls.getMethod("getContext");
+getContextMethod.accessible = true;
+
+var sourceForMethod = sourceCls.getMethod("sourceFor", stringCls, stringCls);
+var scriptCls = compileMethod.invoke(getContextMethod.invoke(null),
+ sourceForMethod.invoke(null, "test", "print('hello')"),
+ ThrowErrorManager.class.newInstance(), false, false);
var SCRIPT_CLASS_NAME_PREFIX = "jdk.nashorn.internal.scripts.Script$";
print("script class name pattern satisfied? " +
diff --git a/nashorn/test/script/nosecurity/JDK-8044851.js b/nashorn/test/script/nosecurity/JDK-8044851.js
index 679c34918d2..8be2fe2b456 100644
--- a/nashorn/test/script/nosecurity/JDK-8044851.js
+++ b/nashorn/test/script/nosecurity/JDK-8044851.js
@@ -25,13 +25,32 @@
* JDK-8044851: nashorn properties leak memory
*
* @test
- * @run
* @option -Dnashorn.debug=true
* @fork
*/
+var Property = Java.type("jdk.nashorn.internal.runtime.Property");
+var PropertyMap = Java.type("jdk.nashorn.internal.runtime.PropertyMap");
+
+// Class objects
+var objectCls = Java.type("java.lang.Object").class;
+var propertyCls = Property.class;
+var propertyMapCls = PropertyMap.class;
+
+// Method objects
+var findPropertyMethod = propertyMapCls.getMethod("findProperty", objectCls);
+var getKeyMethod = propertyCls.getMethod("getKey");
+var isSpillMethod = propertyCls.getMethod("isSpill");
+var getSlotMethod = propertyCls.getMethod("getSlot");
+
function printProperty(value, property) {
- print(value, property.getKey(), property.isSpill() ? "spill" : "field", property.getSlot());
+ print(value, getKeyMethod.invoke(property),
+ isSpillMethod.invoke(property) ? "spill" : "field", getSlotMethod.invoke(property));
+}
+
+function findProperty(obj, name) {
+ var map = Debug.map(obj);
+ return findPropertyMethod.invoke(map, name);
}
var obj = {}, i, name;
@@ -39,7 +58,7 @@ var obj = {}, i, name;
for (i = 0; i < 8; ++i) {
name = 'property' + i;
obj[name] = 'a' + i;
- printProperty(obj[name], Debug.map(obj).findProperty(name));
+ printProperty(obj[name], findProperty(obj, name));
}
print();
@@ -51,14 +70,14 @@ for (i = 0; i < 8; ++i) {
for (i = 0; i < 8; ++i) {
name = 'property' + i;
obj[name] = 'b' + i;
- printProperty(obj[name], Debug.map(obj).findProperty(name));
+ printProperty(obj[name], findProperty(obj, name));
}
print();
for (i = 0; i < 8; ++i) {
name = 'property' + i;
Object.defineProperty(obj, name, {get: function() {return i;}, set: function(v) {}, configurable: true});
- printProperty(obj[name], Debug.map(obj).findProperty(name));
+ printProperty(obj[name], findProperty(obj, name));
}
print();
@@ -70,7 +89,7 @@ for (i = 0; i < 8; ++i) {
for (i = 0; i < 8; ++i) {
name = 'property' + i;
obj[name] = 'c' + i;
- printProperty(obj[name], Debug.map(obj).findProperty(name));
+ printProperty(obj[name], findProperty(obj, name));
}
print();
@@ -82,12 +101,12 @@ for (i = 7; i > -1; --i) {
for (i = 0; i < 8; ++i) {
name = 'property' + i;
obj[name] = 'd' + i;
- printProperty(obj[name], Debug.map(obj).findProperty(name));
+ printProperty(obj[name], findProperty(obj, name));
}
print();
for (i = 0; i < 8; ++i) {
name = 'property' + i;
Object.defineProperty(obj, name, {get: function() {return i;}, set: function(v) {}});
- printProperty(obj[name], Debug.map(obj).findProperty(name));
+ printProperty(obj[name], findProperty(obj, name));
}
diff --git a/nashorn/test/script/nosecurity/JDK-8067215.js b/nashorn/test/script/nosecurity/JDK-8067215.js
index b18163af5fa..e6e55978571 100644
--- a/nashorn/test/script/nosecurity/JDK-8067215.js
+++ b/nashorn/test/script/nosecurity/JDK-8067215.js
@@ -27,6 +27,7 @@
* @test
* @run
* @option -Dnashorn.debug=true
+ * @option -scripting
* @fork
*/
@@ -36,10 +37,27 @@ var objectType = Java.type("java.lang.Object");
var Context = Java.type("jdk.nashorn.internal.runtime.Context");
var JSType = Java.type("jdk.nashorn.internal.runtime.JSType");
+var Property = Java.type("jdk.nashorn.internal.runtime.Property");
+var PropertyMap = Java.type("jdk.nashorn.internal.runtime.PropertyMap");
-var context = Context.getContext();
-var dualFields = context.useDualFields();
-var optimisticTypes = context.getEnv()._optimistic_types;
+// Class objects
+var objectCls = Java.type("java.lang.Object").class;
+var contextCls = Context.class;
+var JSTypeCls = JSType.class;
+var propertyCls = Property.class;
+var propertyMapCls = PropertyMap.class;
+
+// Method objects
+var getContextMethod = contextCls.getMethod("getContext");
+var isRepresentableAsIntMethod = JSTypeCls.getMethod("isRepresentableAsInt", java.lang.Double.TYPE);
+var hasDualFieldsMethod = propertyCls.getMethod("hasDualFields");
+var getTypeMethod = propertyCls.getMethod("getType");
+var findPropertyMethod = propertyMapCls.getMethod("findProperty", objectCls);
+
+var context = getContextMethod.invoke(null);
+var useDualFieldsMethod = contextCls.getMethod("useDualFields");
+var dualFields = useDualFieldsMethod.invoke(context);
+var optimisticTypes = $OPTIONS._optimistic_types;
if (dualFields != optimisticTypes) {
throw new Error("Wrong dual fields setting");
@@ -51,11 +69,11 @@ function testMap(obj) {
Object.defineProperty(obj, "z", {value: 0.5});
var map = Debug.map(obj);
for (var key in obj) {
- var prop = map.findProperty(key);
- if (prop.hasDualFields() !== dualFields) {
+ var prop = findPropertyMethod.invoke(map, key);
+ if (hasDualFieldsMethod.invoke(prop) !== dualFields) {
throw new Error("Wrong property flags: " + prop);
}
- if (prop.getType() != getExpectedType(obj[key])) {
+ if (getTypeMethod.invoke(prop) != getExpectedType(obj[key])) {
throw new Error("Wrong property type: " + prop.getType() + " // " + getExpectedType(obj[key]));
}
}
@@ -66,7 +84,7 @@ function getExpectedType(value) {
return objectType.class;
}
if (typeof value === "number") {
- return JSType.isRepresentableAsInt(value) ? intType.class : doubleType.class;
+ return isRepresentableAsIntMethod.invoke(null, value) ? intType.class : doubleType.class;
}
return objectType.class;
}
diff --git a/nashorn/test/script/nosecurity/JDK-8078049.js b/nashorn/test/script/nosecurity/JDK-8078049.js
index 6a441a1b571..74e3a627109 100644
--- a/nashorn/test/script/nosecurity/JDK-8078049.js
+++ b/nashorn/test/script/nosecurity/JDK-8078049.js
@@ -543,11 +543,14 @@ var spill = {
var AccessorProperty = Java.type("jdk.nashorn.internal.runtime.AccessorProperty");
var SpillProperty = Java.type("jdk.nashorn.internal.runtime.SpillProperty");
+var PropertyMap = Java.type("jdk.nashorn.internal.runtime.PropertyMap");
+var findPropertyMethod = PropertyMap.class.getMethod("findProperty", java.lang.Object.class);
Assert.assertTrue(Object.keys(fields).length === 3);
-Assert.assertTrue(Debug.map(fields).findProperty("p0").getClass() === AccessorProperty.class);
-Assert.assertTrue(Debug.map(fields).findProperty("p2").getClass() === AccessorProperty.class);
+Assert.assertTrue(findPropertyMethod.invoke(Debug.map(fields), "p0").getClass() === AccessorProperty.class);
+Assert.assertTrue(findPropertyMethod.invoke(Debug.map(fields), "p2").getClass() === AccessorProperty.class);
Assert.assertTrue(Object.keys(spill).length === 500);
-Assert.assertTrue(Debug.map(spill).findProperty("p0").getClass() === SpillProperty.class);
-Assert.assertTrue(Debug.map(spill).findProperty("p499").getClass() === SpillProperty.class);
+
+Assert.assertTrue(findPropertyMethod.invoke(Debug.map(spill), "p0").getClass() === SpillProperty.class);
+Assert.assertTrue(findPropertyMethod.invoke(Debug.map(spill), "p499").getClass() === SpillProperty.class);
diff --git a/nashorn/test/script/trusted/classfilter_extends.js.EXPECTED b/nashorn/test/script/trusted/classfilter_extends.js.EXPECTED
index e0cf856b8ed..884e95abc48 100644
--- a/nashorn/test/script/trusted/classfilter_extends.js.EXPECTED
+++ b/nashorn/test/script/trusted/classfilter_extends.js.EXPECTED
@@ -6,9 +6,9 @@ java.lang.ClassNotFoundException: java.lang.String
[JavaClass java.util.ArrayList]
[JavaClass java.lang.String]
[JavaPackage java.lang.String]
-[JavaClass jdk.nashorn.javaadapters.java.util.ArrayList]
-[JavaClass jdk.nashorn.javaadapters.java.util.ArrayList]
-[JavaClass jdk.nashorn.javaadapters.java.io.File]
+[JavaClass jdk.nashorn.javaadapters.java_util_ArrayList]
+[JavaClass jdk.nashorn.javaadapters.java_util_ArrayList]
+[JavaClass jdk.nashorn.javaadapters.java_io_File]
TypeError: Java.extend needs Java types as its arguments. in at line number 1
java.lang.NullPointerException
java.lang.ClassNotFoundException: java.lang.NullPointerException
diff --git a/nashorn/test/script/trusted/classfilter_mozilla_compat.js.EXPECTED b/nashorn/test/script/trusted/classfilter_mozilla_compat.js.EXPECTED
index 9481e98e182..7491e443b91 100644
--- a/nashorn/test/script/trusted/classfilter_mozilla_compat.js.EXPECTED
+++ b/nashorn/test/script/trusted/classfilter_mozilla_compat.js.EXPECTED
@@ -1,7 +1,7 @@
-class javax.script.ScriptContext$$NashornJavaAdapter
+class jdk.nashorn.javaadapters.javax_script_ScriptContext
TypeError: Java.extend needs at least one type argument. in nashorn:mozilla_compat.js at line number 39
-class jdk.nashorn.javaadapters.java.util.ArrayList
-class jdk.nashorn.javaadapters.java.util.ArrayList
+class jdk.nashorn.javaadapters.java_util_ArrayList
+class jdk.nashorn.javaadapters.java_util_ArrayList
[JavaClass java.lang.Integer]
TypeError: [object JavaPackage] is not a Java class in nashorn:mozilla_compat.js at line number 373 at column number 16
[JavaClass java.util.HashSet]
diff --git a/nashorn/test/script/trusted/event_queue.js b/nashorn/test/script/trusted/event_queue.js
index feecc201da5..22a86a23787 100644
--- a/nashorn/test/script/trusted/event_queue.js
+++ b/nashorn/test/script/trusted/event_queue.js
@@ -30,6 +30,7 @@
* @option -Dnashorn.debug=true
* @option --log=recompile:quiet
* @option --optimistic-types=true
+ * @run
*/
print(Debug);
diff --git a/nashorn/test/script/trusted/optimistic_recompilation.js b/nashorn/test/script/trusted/optimistic_recompilation.js
index 9c9a9c751b0..9d9724d0f93 100644
--- a/nashorn/test/script/trusted/optimistic_recompilation.js
+++ b/nashorn/test/script/trusted/optimistic_recompilation.js
@@ -29,6 +29,7 @@
* @option -Dnashorn.debug=true
* @option --log=recompile:quiet
* @option --optimistic-types=true
+ * @run
*/
var forName = java.lang.Class["forName(String)"];
diff --git a/nashorn/test/src/jdk/nashorn/internal/runtime/doubleconv/test/BignumTest.java b/nashorn/test/src/jdk/nashorn/internal/runtime/doubleconv/test/BignumTest.java
index 76c99d57489..4f2bb9d9fdf 100644
--- a/nashorn/test/src/jdk/nashorn/internal/runtime/doubleconv/test/BignumTest.java
+++ b/nashorn/test/src/jdk/nashorn/internal/runtime/doubleconv/test/BignumTest.java
@@ -69,6 +69,7 @@ import static org.testng.Assert.assertTrue;
* Bignum class tests
*
* @test
+ * @modules jdk.scripting.nashorn/jdk.nashorn.internal.runtime.doubleconv
* @run testng jdk.nashorn.internal.runtime.doubleconv.test.BignumTest
*/
@SuppressWarnings("javadoc")
diff --git a/nashorn/test/src/jdk/nashorn/internal/runtime/doubleconv/test/DiyFpTest.java b/nashorn/test/src/jdk/nashorn/internal/runtime/doubleconv/test/DiyFpTest.java
index 00e49eabffb..5432e53f670 100644
--- a/nashorn/test/src/jdk/nashorn/internal/runtime/doubleconv/test/DiyFpTest.java
+++ b/nashorn/test/src/jdk/nashorn/internal/runtime/doubleconv/test/DiyFpTest.java
@@ -44,6 +44,7 @@ import static org.testng.Assert.assertTrue;
* DiyFp class tests
*
* @test
+ * @modules jdk.scripting.nashorn/jdk.nashorn.internal.runtime.doubleconv
* @run testng jdk.nashorn.internal.runtime.doubleconv.test.DiyFpTest
*/
@SuppressWarnings("javadoc")
diff --git a/nashorn/test/src/jdk/nashorn/internal/runtime/regexp/joni/test/JoniTest.java b/nashorn/test/src/jdk/nashorn/internal/runtime/regexp/joni/test/JoniTest.java
index a907f8f1989..27ffd841ed7 100644
--- a/nashorn/test/src/jdk/nashorn/internal/runtime/regexp/joni/test/JoniTest.java
+++ b/nashorn/test/src/jdk/nashorn/internal/runtime/regexp/joni/test/JoniTest.java
@@ -32,6 +32,7 @@ import org.testng.annotations.Test;
* Joni coverage tests
*
* @test
+ * @modules jdk.scripting.nashorn/jdk.nashorn.internal.runtime.regexp.joni
* @run testng jdk.nashorn.internal.runtime.regexp.joni.test.JoniTest
*/
@SuppressWarnings("javadoc")
diff --git a/nashorn/test/src/jdk/nashorn/internal/runtime/regexp/test/JdkRegExpTest.java b/nashorn/test/src/jdk/nashorn/internal/runtime/regexp/test/JdkRegExpTest.java
index 20cb36722f0..32d5d42acc9 100644
--- a/nashorn/test/src/jdk/nashorn/internal/runtime/regexp/test/JdkRegExpTest.java
+++ b/nashorn/test/src/jdk/nashorn/internal/runtime/regexp/test/JdkRegExpTest.java
@@ -38,6 +38,7 @@ import org.testng.annotations.Test;
* Basic tests for the JDK based RegExp implementation.
*
* @test
+ * @modules jdk.scripting.nashorn/jdk.nashorn.internal.runtime.regexp
* @run testng jdk.nashorn.internal.runtime.regexp.test.JdkRegExpTest
*/
public class JdkRegExpTest {
diff --git a/nashorn/test/src/jdk/nashorn/internal/runtime/test/ConsStringTest.java b/nashorn/test/src/jdk/nashorn/internal/runtime/test/ConsStringTest.java
index f86c5b75d2c..12f49028fa6 100644
--- a/nashorn/test/src/jdk/nashorn/internal/runtime/test/ConsStringTest.java
+++ b/nashorn/test/src/jdk/nashorn/internal/runtime/test/ConsStringTest.java
@@ -34,6 +34,7 @@ import org.testng.annotations.Test;
* Tests for JSType methods.
*
* @test
+ * @modules jdk.scripting.nashorn/jdk.nashorn.internal.runtime
* @run testng jdk.nashorn.internal.runtime.test.ConsStringTest
*/
public class ConsStringTest {
diff --git a/nashorn/test/src/jdk/nashorn/internal/runtime/test/ContextTest.java b/nashorn/test/src/jdk/nashorn/internal/runtime/test/ContextTest.java
index b927de2e965..35f902e66b9 100644
--- a/nashorn/test/src/jdk/nashorn/internal/runtime/test/ContextTest.java
+++ b/nashorn/test/src/jdk/nashorn/internal/runtime/test/ContextTest.java
@@ -44,6 +44,9 @@ import org.testng.annotations.Test;
* Basic Context API tests.
*
* @test
+ * @modules jdk.scripting.nashorn/jdk.nashorn.internal.runtime
+ * jdk.scripting.nashorn/jdk.nashorn.internal.runtime.options
+ * jdk.scripting.nashorn/jdk.nashorn.internal.objects
* @run testng jdk.nashorn.internal.runtime.test.ContextTest
*/
@SuppressWarnings("javadoc")
diff --git a/nashorn/test/src/jdk/nashorn/internal/runtime/test/ExceptionsNotSerializable.java b/nashorn/test/src/jdk/nashorn/internal/runtime/test/ExceptionsNotSerializable.java
index 2f498af3cbc..cac02e0eed0 100644
--- a/nashorn/test/src/jdk/nashorn/internal/runtime/test/ExceptionsNotSerializable.java
+++ b/nashorn/test/src/jdk/nashorn/internal/runtime/test/ExceptionsNotSerializable.java
@@ -42,6 +42,7 @@ import org.testng.annotations.Test;
* JDK-8044518: Ensure exceptions related to optimistic recompilation are not serializable
*
* @test
+ * @modules jdk.scripting.nashorn/jdk.nashorn.internal.runtime
* @run testng jdk.nashorn.internal.runtime.test.ExceptionsNotSerializable
*/
@SuppressWarnings("javadoc")
diff --git a/nashorn/test/src/jdk/nashorn/internal/runtime/test/JDK_8078414_Test.java b/nashorn/test/src/jdk/nashorn/internal/runtime/test/JDK_8078414_Test.java
index 30755ed7ea2..845cc1a5900 100644
--- a/nashorn/test/src/jdk/nashorn/internal/runtime/test/JDK_8078414_Test.java
+++ b/nashorn/test/src/jdk/nashorn/internal/runtime/test/JDK_8078414_Test.java
@@ -47,6 +47,10 @@ import org.testng.annotations.Test;
* @test
* @bug 8078414
* @summary Test that arbitrary classes can't be converted to mirror's superclasses/interfaces.
+ * @modules jdk.scripting.nashorn/jdk.nashorn.internal.runtime
+ * @modules jdk.scripting.nashorn/jdk.nashorn.internal.runtime.linker
+ * @modules jdk.scripting.nashorn/jdk.nashorn.internal.runtime.options
+ * @modules jdk.scripting.nashorn/jdk.nashorn.internal.objects
* @run testng jdk.nashorn.internal.runtime.test.JDK_8078414_Test
*/
public class JDK_8078414_Test {
diff --git a/nashorn/test/src/jdk/nashorn/internal/runtime/test/JSTypeTest.java b/nashorn/test/src/jdk/nashorn/internal/runtime/test/JSTypeTest.java
index a91a442adf9..9d0c0bb8f3b 100644
--- a/nashorn/test/src/jdk/nashorn/internal/runtime/test/JSTypeTest.java
+++ b/nashorn/test/src/jdk/nashorn/internal/runtime/test/JSTypeTest.java
@@ -37,6 +37,7 @@ import org.testng.annotations.Test;
* Tests for JSType methods.
*
* @test
+ * @modules jdk.scripting.nashorn/jdk.nashorn.internal.runtime
* @run testng jdk.nashorn.internal.runtime.test.JSTypeTest
*/
public class JSTypeTest {
diff --git a/nashorn/test/src/jdk/nashorn/internal/test/framework/ScriptRunnable.java b/nashorn/test/src/jdk/nashorn/internal/test/framework/ScriptRunnable.java
index 8ca3405701b..3e3c9512756 100644
--- a/nashorn/test/src/jdk/nashorn/internal/test/framework/ScriptRunnable.java
+++ b/nashorn/test/src/jdk/nashorn/internal/test/framework/ScriptRunnable.java
@@ -176,8 +176,6 @@ public final class ScriptRunnable extends AbstractScriptRunnable implements ITes
final List cmd = new ArrayList<>();
cmd.add(System.getProperty("java.home") + separator + "bin" + separator + "java");
- // cmd.add("-Djava.ext.dirs=dist");
- cmd.add("-Xbootclasspath/a:dist/nashorn.jar");
for (final String str : forkJVMOptions) {
if(!str.isEmpty()) {
cmd.add(str);