# HG changeset patch # User alanb # Date 1462262985 -3600 # Node ID 45821736044ee8f99cce5348740e4bcab8cdda65 # Parent 7210f0a2c64a4de78223465c4819cbc0a178ad20 8154956: Module system implementation refresh (4/2016) Reviewed-by: mchung, chegar, redestad diff -r 7210f0a2c64a -r 45821736044e jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/trax/TemplatesImpl.java --- a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/trax/TemplatesImpl.java Thu Apr 28 08:26:36 2016 -0700 +++ b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/trax/TemplatesImpl.java Tue May 03 09:09:45 2016 +0100 @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2016, Oracle and/or its affiliates. All rights reserved. */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -32,19 +32,26 @@ import com.sun.org.apache.xalan.internal.xsltc.compiler.util.ErrorMsg; import com.sun.org.apache.xalan.internal.xsltc.runtime.AbstractTranslet; import java.io.IOException; +import java.io.UncheckedIOException; import java.io.NotSerializableException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.ObjectStreamField; import java.io.Serializable; -import java.util.Arrays; -import java.util.Collections; +import java.lang.module.Configuration; +import java.lang.module.ModuleDescriptor; +import java.lang.module.ModuleFinder; +import java.lang.module.ModuleReference; +import java.lang.reflect.Layer; +import java.lang.reflect.Module; import java.security.AccessController; import java.security.PrivilegedAction; -import java.lang.reflect.Module; +import java.util.Arrays; import java.util.HashMap; import java.util.Map; +import java.util.Optional; import java.util.Properties; +import java.util.Set; import javax.xml.XMLConstants; import javax.xml.transform.Templates; import javax.xml.transform.Transformer; @@ -389,6 +396,48 @@ return _name; } + + /** + * Creates a module layer with one module that is defined to the given class + * loader. + */ + private Module createModule(ModuleDescriptor descriptor, ClassLoader loader) { + String mn = descriptor.name(); + + ModuleReference mref = new ModuleReference(descriptor, null, () -> { + IOException ioe = new IOException(""); + throw new UncheckedIOException(ioe); + }); + + ModuleFinder finder = new ModuleFinder() { + @Override + public Optional find(String name) { + if (name.equals(mn)) { + return Optional.of(mref); + } else { + return Optional.empty(); + } + } + @Override + public Set findAll() { + return Set.of(mref); + } + }; + + Layer bootLayer = Layer.boot(); + + Configuration cf = bootLayer.configuration() + .resolveRequires(finder, ModuleFinder.empty(), Set.of(mn)); + + PrivilegedAction pa = () -> bootLayer.defineModules(cf, name -> loader); + Layer layer = AccessController.doPrivileged(pa); + + Module m = layer.findModule(mn).get(); + assert m.getLayer() == layer; + + return m; + } + /** * Defines the translet class and auxiliary classes. * Returns a reference to the Class object that defines the main class @@ -417,29 +466,32 @@ } // create a module for the translet - Module xmlModule = TemplatesImpl.class.getModule(); + + String mn = "jdk.translet"; + String pn = _tfactory.getPackageName(); assert pn != null && pn.length() > 0; - Module m = Modules.defineModule(loader, "jdk.translet", - Collections.singleton(pn)); + ModuleDescriptor descriptor + = new ModuleDescriptor.Builder(mn) + .requires("java.xml") + .exports(pn) + .build(); - // jdk.translate reads java.base && java.xml - Modules.addReads(m, Object.class.getModule()); - Modules.addReads(m, xmlModule); + Module m = createModule(descriptor, loader); - // jdk.translet needs access to runtime classes + // the module needs access to runtime classes + Module thisModule = TemplatesImpl.class.getModule(); Arrays.asList(Constants.PKGS_USED_BY_TRANSLET_CLASSES).forEach(p -> { - xmlModule.addExports(p, m); + thisModule.addExports(p, m); }); - // jdk.translate also needs to be loose as the XSL may bind to - // java types in an unnamed module - Modules.addReads(m, null); + // For now, the module reads all unnnamed modules. This will be changed once + // the XSLT compiler is updated to generate code to invoke addReads. + Modules.addReadsAllUnnamed(m); - // java.xml needs to instanitate the translate class - xmlModule.addReads(m); - Modules.addExports(m, pn, xmlModule); + // java.xml needs to instanitate the translet class + thisModule.addReads(m); for (int i = 0; i < classCount; i++) { _class[i] = loader.defineClass(_bytecodes[i]); diff -r 7210f0a2c64a -r 45821736044e jaxp/test/ProblemList.txt --- a/jaxp/test/ProblemList.txt Thu Apr 28 08:26:36 2016 -0700 +++ b/jaxp/test/ProblemList.txt Tue May 03 09:09:45 2016 +0100 @@ -26,3 +26,6 @@ # 8147431 javax/xml/jaxp/isolatedjdk/catalog/PropertiesTest.sh generic-all +# 8150145 +javax/xml/jaxp/unittest/common/TransformationWarningsTest.java generic-all + diff -r 7210f0a2c64a -r 45821736044e jaxp/test/TEST.ROOT --- a/jaxp/test/TEST.ROOT Thu Apr 28 08:26:36 2016 -0700 +++ b/jaxp/test/TEST.ROOT Tue May 03 09:09:45 2016 +0100 @@ -18,4 +18,4 @@ groups=TEST.groups # Minimum jtreg version -requiredVersion=4.2 b01 +requiredVersion=4.2 b02