--- old/modules/jdk.packager/src/main/java/com/sun/javafx/tools/ant/FXJar.java 2016-11-02 13:32:20.915529864 -0400 +++ /dev/null 2016-10-31 09:37:02.128008072 -0400 @@ -1,241 +0,0 @@ -/* - * Copyright (c) 2011, 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. - */ - -package com.sun.javafx.tools.ant; - -import com.sun.javafx.tools.packager.CreateJarParams; -import com.sun.javafx.tools.packager.PackagerLib; -import java.io.File; -import java.util.Enumeration; -import java.util.HashMap; -import java.util.LinkedList; -import java.util.List; -import java.util.Map; -import org.apache.tools.ant.BuildException; -import org.apache.tools.ant.Task; -import org.apache.tools.ant.taskdefs.Manifest; -import org.apache.tools.ant.types.FileSet; - -/** - * Package javafx application into jar file. The set of files to be included is - * defined by one or more nested fileset. Task also accepts jar Manifest to embed it into - * result jar file. - *

- * In addition to just creating jar archive it also: - *

- * - * @ant.task name="jar" category="javafx" - */ -public class FXJar extends Task { - private String destFile = null; - private String codebase = null; - private Application app = null; - private Platform platform = null; - private Resources resources = null; - private List filesets = new LinkedList(); - private Manifest manifest = null; - - private PackagerLib packager; - private CreateJarParams createJarParams; - - private boolean css2bin = false; - - private boolean verbose = false; - public void setVerbose(boolean v) { - verbose = v; - } - - public Application createApplication() { - app = new Application(); - return app; - } - - public Platform createPlatform() { - platform = new Platform(); - return platform; - } - - private Permissions perms = null; - - public Permissions createPermissions() { - perms = new Permissions(); - return perms; - } - - public Resources createResources() { - resources = new Resources(); - return resources; - } - - /** - * Location of output file. - * - * @ant.required - */ - public void setDestfile(String v) { - destFile = v; - } - - /* - * If specified, then packager adds the "Codebase" attribute to the manifest file - * - * @ant.not-required Default is null. - */ - public void setCodebase(String v) { - codebase = v; - } - - /** - * Enable converting CSS files to binary format for faster parsing at - * runtime. - * - * @ant.not-required Default is false. - */ - public void setCss2Bin(boolean v) { - css2bin = v; - } - - public FXJar() { - packager = new PackagerLib(); - createJarParams = new CreateJarParams(); - } - - - @Override - public void execute() { - checkAttributesAndElements(); - - createJarParams.setCss2bin(css2bin); - - if (app != null) { - createJarParams.setApplicationClass(app.get().mainClass); - createJarParams.setPreloader(app.get().preloaderClass); - createJarParams.setFallback(app.get().fallbackApp); - createJarParams.setParams(app.get().parameters); - createJarParams.setArguments(app.get().getArguments()); - } - - if (perms != null) { - createJarParams.setAllPermissions(perms.getElevated()); - } - - if (codebase != null) { - createJarParams.setCodebase(codebase); - } - - if (platform != null) { - createJarParams.setFxVersion(platform.get().javafx); - } - - if (resources != null) { - createJarParams.setClasspath(resources.exportAsClassPath()); - } - - final File f = new File(destFile); - createJarParams.setOutdir(f.isAbsolute() - ? null - : getProject().getBaseDir()); - createJarParams.setOutfile(destFile); - - if (manifest != null) { - createJarParams.setManifestAttrs(getAttrSet(manifest)); - } - - for (FileSet fileset: filesets) { - Utils.addResources(createJarParams, fileset); - } - - try { - packager.packageAsJar(createJarParams); - } catch (Exception e) { - throw new BuildException(e.getMessage(), e); - } - } - - public Manifest createManifest() { - manifest = new Manifest(); - return manifest; - } - - public FileSet createFileSet() { - FileSet fileset = new FileSet(); - fileset.setProject(getProject()); - filesets.add(fileset); - return fileset; - } - - private void checkAttributesAndElements() { - if (destFile == null) { - throw new BuildException("You must specify the destfile file to create."); - } - - File f = new File(destFile); - if (!f.isAbsolute()) { - f = new File(getProject().getBaseDir(), destFile); - } - if (f.exists() && !f.isFile()) { - throw new BuildException(destFile + " is not a file."); - } - - if (f.exists() && !f.canWrite()) { - throw new BuildException(destFile + " is read-only."); - } - - if (filesets.isEmpty()) { - throw new BuildException("You must specify at least one fileset to be packed."); - } - - boolean haveNonEmpty = false; - for (FileSet fileset: filesets) { - if (fileset.size() != 0) { - haveNonEmpty = true; - break; - } - } - - if (!haveNonEmpty) { - throw new BuildException("All filesets are empty."); - } - - if (app != null) { - app.selfcheck(); - } - } - - private static Map getAttrSet(Manifest manifest) { - Map result = new HashMap(); - - Manifest.Section mainSection = manifest.getMainSection(); - for (Enumeration e = mainSection.getAttributeKeys(); e.hasMoreElements();) { - String attrKey = (String) e.nextElement(); - Manifest.Attribute attr = mainSection.getAttribute(attrKey); - result.put(attr.getName(), attr.getValue()); - } - return result; - } -} --- /dev/null 2016-10-31 09:37:02.128008072 -0400 +++ new/modules/jdk.packager/src/antplugin/java/com/sun/javafx/tools/ant/FXJar.java 2016-11-02 13:32:20.759533409 -0400 @@ -0,0 +1,241 @@ +/* + * Copyright (c) 2011, 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. + */ + +package com.sun.javafx.tools.ant; + +import com.sun.javafx.tools.packager.CreateJarParams; +import com.sun.javafx.tools.packager.PackagerLib; +import java.io.File; +import java.util.Enumeration; +import java.util.HashMap; +import java.util.LinkedList; +import java.util.List; +import java.util.Map; +import org.apache.tools.ant.BuildException; +import org.apache.tools.ant.Task; +import org.apache.tools.ant.taskdefs.Manifest; +import org.apache.tools.ant.types.FileSet; + +/** + * Package javafx application into jar file. The set of files to be included is + * defined by one or more nested fileset. Task also accepts jar Manifest to embed it into + * result jar file. + *

+ * In addition to just creating jar archive it also: + *

    + *
  • embeds of JavaFX launcher (for double clickable jars) + *
  • ensures jar manifests do not have "bad" entries (such as Class-Path) + *
+ * + * @ant.task name="jar" category="javafx" + */ +public class FXJar extends Task { + private String destFile = null; + private String codebase = null; + private Application app = null; + private Platform platform = null; + private Resources resources = null; + private List filesets = new LinkedList(); + private Manifest manifest = null; + + private PackagerLib packager; + private CreateJarParams createJarParams; + + private boolean css2bin = false; + + private boolean verbose = false; + public void setVerbose(boolean v) { + verbose = v; + } + + public Application createApplication() { + app = new Application(); + return app; + } + + public Platform createPlatform() { + platform = new Platform(); + return platform; + } + + private Permissions perms = null; + + public Permissions createPermissions() { + perms = new Permissions(); + return perms; + } + + public Resources createResources() { + resources = new Resources(); + return resources; + } + + /** + * Location of output file. + * + * @ant.required + */ + public void setDestfile(String v) { + destFile = v; + } + + /* + * If specified, then packager adds the "Codebase" attribute to the manifest file + * + * @ant.not-required Default is null. + */ + public void setCodebase(String v) { + codebase = v; + } + + /** + * Enable converting CSS files to binary format for faster parsing at + * runtime. + * + * @ant.not-required Default is false. + */ + public void setCss2Bin(boolean v) { + css2bin = v; + } + + public FXJar() { + packager = new PackagerLib(); + createJarParams = new CreateJarParams(); + } + + + @Override + public void execute() { + checkAttributesAndElements(); + + createJarParams.setCss2bin(css2bin); + + if (app != null) { + createJarParams.setApplicationClass(app.get().mainClass); + createJarParams.setPreloader(app.get().preloaderClass); + createJarParams.setFallback(app.get().fallbackApp); + createJarParams.setParams(app.get().parameters); + createJarParams.setArguments(app.get().getArguments()); + } + + if (perms != null) { + createJarParams.setAllPermissions(perms.getElevated()); + } + + if (codebase != null) { + createJarParams.setCodebase(codebase); + } + + if (platform != null) { + createJarParams.setFxVersion(platform.get().javafx); + } + + if (resources != null) { + createJarParams.setClasspath(resources.exportAsClassPath()); + } + + final File f = new File(destFile); + createJarParams.setOutdir(f.isAbsolute() + ? null + : getProject().getBaseDir()); + createJarParams.setOutfile(destFile); + + if (manifest != null) { + createJarParams.setManifestAttrs(getAttrSet(manifest)); + } + + for (FileSet fileset: filesets) { + Utils.addResources(createJarParams, fileset); + } + + try { + packager.packageAsJar(createJarParams); + } catch (Exception e) { + throw new BuildException(e.getMessage(), e); + } + } + + public Manifest createManifest() { + manifest = new Manifest(); + return manifest; + } + + public FileSet createFileSet() { + FileSet fileset = new FileSet(); + fileset.setProject(getProject()); + filesets.add(fileset); + return fileset; + } + + private void checkAttributesAndElements() { + if (destFile == null) { + throw new BuildException("You must specify the destfile file to create."); + } + + File f = new File(destFile); + if (!f.isAbsolute()) { + f = new File(getProject().getBaseDir(), destFile); + } + if (f.exists() && !f.isFile()) { + throw new BuildException(destFile + " is not a file."); + } + + if (f.exists() && !f.canWrite()) { + throw new BuildException(destFile + " is read-only."); + } + + if (filesets.isEmpty()) { + throw new BuildException("You must specify at least one fileset to be packed."); + } + + boolean haveNonEmpty = false; + for (FileSet fileset: filesets) { + if (fileset.size() != 0) { + haveNonEmpty = true; + break; + } + } + + if (!haveNonEmpty) { + throw new BuildException("All filesets are empty."); + } + + if (app != null) { + app.selfcheck(); + } + } + + private static Map getAttrSet(Manifest manifest) { + Map result = new HashMap(); + + Manifest.Section mainSection = manifest.getMainSection(); + for (Enumeration e = mainSection.getAttributeKeys(); e.hasMoreElements();) { + String attrKey = (String) e.nextElement(); + Manifest.Attribute attr = mainSection.getAttribute(attrKey); + result.put(attr.getName(), attr.getValue()); + } + return result; + } +}