diff -r 3ee4e7827413 -r 640a383428fb jaxws/src/jdk.xml.bind/share/classes/com/sun/codemodel/internal/JCodeModel.java --- a/jaxws/src/jdk.xml.bind/share/classes/com/sun/codemodel/internal/JCodeModel.java Wed Jul 05 22:27:20 2017 +0200 +++ b/jaxws/src/jdk.xml.bind/share/classes/com/sun/codemodel/internal/JCodeModel.java Tue Nov 15 23:43:38 2016 +0300 @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 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 @@ -39,7 +39,6 @@ import com.sun.codemodel.internal.writer.FileCodeWriter; import com.sun.codemodel.internal.writer.ProgressCodeWriter; - /** * Root of the code DOM. * @@ -80,10 +79,13 @@ public final class JCodeModel { /** The packages that this JCodeWriter contains. */ - private HashMap packages = new HashMap(); + private final HashMap packages = new HashMap<>(); + + /** Java module in {@code module-info.java} file. */ + private JModule module; /** All JReferencedClasses are pooled here. */ - private final HashMap,JReferencedClass> refClasses = new HashMap,JReferencedClass>(); + private final HashMap,JReferencedClass> refClasses = new HashMap<>(); /** Obtains a reference to the special "null" type. */ @@ -121,7 +123,7 @@ public JCodeModel() {} /** - * Add a package to the list of packages to be generated + * Add a package to the list of packages to be generated. * * @param name * Name of the package. Use "" to indicate the root package. @@ -137,6 +139,50 @@ return p; } + /** + * Creates and returns Java module to be generated. + * @param name The Name of Java module. + * @return New Java module. + */ + public JModule _moduleInfo(final String name) { + return module = new JModule(name); + } + + /** + * Returns existing Java module to be generated. + * @return Java module or {@code null} if Java module was not created yet. + */ + public JModule _getModuleInfo() { + return module; + } + + /** + * Creates Java module instance and adds existing packages with classes to the Java module info. + * Used to initialize and build Java module instance with existing packages content. + * @param name The Name of Java module. + * @param requires Requires directives to add. + * @throws IllegalStateException when Java module instance was not initialized. + */ + public void _prepareModuleInfo(final String name, final String ...requires) { + _moduleInfo(name); + _updateModuleInfo(requires); + } + + /** + * Adds existing packages with classes to the Java module info. + * Java module instance must exist before calling this method. + * Used to update Java module instance with existing packages content after it was prepared on client side. + * @param requires Requires directives to add. + * @throws IllegalStateException when Java module instance was not initialized. + */ + public void _updateModuleInfo(final String ...requires) { + if (module == null) { + throw new IllegalStateException("Java module instance was not initialized yet."); + } + module._exports(packages.values(), false); + module._requires(requires); + } + public final JPackage rootPackage() { return _package(""); } @@ -292,8 +338,12 @@ public void build( CodeWriter source, CodeWriter resource ) throws IOException { JPackage[] pkgs = packages.values().toArray(new JPackage[packages.size()]); // avoid concurrent modification exception - for( JPackage pkg : pkgs ) + for( JPackage pkg : pkgs ) { pkg.build(source,resource); + } + if (module != null) { + module.build(source); + } source.close(); resource.close(); }