All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.zenjava.javafx.maven.plugin.AbstractJfxToolsMojo Maven / Gradle / Ivy

Go to download

The JavaFX Maven Plugin provides a way to to assemble distributable bundles for JavaFX applications from within Maven. It provides a wrapper around the JavaFX packaging tools which are provided as part of the JavaFX installation.

There is a newer version: 8.8.3
Show newest version
/*
 * Copyright 2012 Daniel Zwolenski.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.zenjava.javafx.maven.plugin;

import com.oracle.tools.packager.Log;
import com.sun.javafx.tools.packager.PackagerLib;
import org.apache.maven.plugin.AbstractMojo;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.project.MavenProject;

import java.io.File;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLClassLoader;
import java.nio.file.FileVisitResult;
import java.nio.file.FileVisitor;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.StandardCopyOption;
import java.nio.file.attribute.BasicFileAttributes;

/**
 * Base Mojo that any other Mojo wanting to access the JavaFX Packager tools should extend from. This provides
 * convenience methods for accessing the JavaFX Packager tools in a standard and simple way.
 */
public abstract class AbstractJfxToolsMojo extends AbstractMojo {

    /**
     * The Maven Project Object
     *
     * @parameter property="project"
     * @required
     * @readonly
     */
    protected MavenProject project;

    /**
     * Flag to turn on verbose logging. Set this to true if you are having problems and want more detailed information.
     *
     * @parameter property="jfx.verbose" default-value="false"
     */
    protected Boolean verbose;

    /**
     * The main JavaFX application class that acts as the entry point to the JavaFX application.
     *
     * @parameter property="jfx.mainClass"
     * @required
     */
    protected String mainClass;

    /**
     * The 'app' output directory. This is where the base executable JavaFX jar is built into, along with any dependent
     * libraries (place in the 'lib' sub-directory). The resulting JAR in this directory will be ready for distribution,
     * including Pre-Loaders, signing, etc. This JAR will also be the one bundled into the other distribution bundles
     * (i.e. web or native) if you run the relevant commands for that.
     * 

* This defaults to 'target/jfx/app' and in most cases there is no real need to change this. * * @parameter property="jfx.jfxAppOutputDir" default-value="${project.build.directory}/jfx/app" */ protected File jfxAppOutputDir; /** * The name of the JavaFX packaged JAR to be built into the 'app' directory. By default this will be the finalName * as set in your project with a '-jfx' suffix. Change this if you want something nicer. Note, that changing this * value does not affect the regular old, non-JFX modified JAR (built in the 'target' directory). * * @parameter property="jfx.jfxMainAppJarName" default-value="${project.build.finalName}-jfx.jar" */ protected String jfxMainAppJarName; /** * The directory contain deployment specific files, such as icons and splash screen images. This directory is added * to the classpath of the Mojo when it runs, so that any files within this directory are accessible to the * JavaFX packaging tools. *

* This defaults to src/main/deploy and typically this is good enough. Just put your deployment specific files in * this directory and they will be automatically picked up. *

* The most common usage for this is to provide platform specific icons for native bundles. In this case you need * to follow the convention of the JavaFX packaging tools to ensure your icons get picked up. * *

    *
  • for windows put an icon at src/main/deploy/package/windows/your-app-name.ico
  • *
  • for mac put an icon at src/main/deploy/package/macosx/your-app-name.icns
  • *
* * @parameter property="jfx.deployDir" default-value="${project.basedir}/src/main/deploy" */ protected String deployDir; /** * All commands executed by this Maven-plugin will be done using the current available commands * of your maven-execution environment. It is possible to call Maven with a different version of Java, * so these calls might be wrong. To use the executables of the JDK used for running this maven-plugin, * please set this to false. You might need this in the case you installed multiple versions of Java. * * The default is to use environment relative executables. * * @parameter property="jfx.useEnvironmentRelativeExecutables" default-value="true" */ protected boolean useEnvironmentRelativeExecutables; /** * Set this to true for skipping the execution. * * @parameter property="jfx.skip" default-value="false" */ protected boolean skip; /** * All dependencies are copied to a separated folder, which can be changed. * * @since 8.8.0 * * @parameter property="jfx.libFolderName" default-value="lib" */ protected String libFolderName; private PackagerLib packagerLib; public PackagerLib getPackagerLib() throws MojoExecutionException { // lazy-initialization of packagerLib if( packagerLib == null ){ // add deployDir to system classpath if( deployDir != null ){ getLog().info("Adding 'deploy' directory to Mojo classpath: " + deployDir); URLClassLoader sysloader = (URLClassLoader) Thread.currentThread().getContextClassLoader(); Class sysclass = URLClassLoader.class; try{ Method method = sysclass.getDeclaredMethod("addURL", URL.class); method.setAccessible(true); method.invoke(sysloader, new File(deployDir).toURI().toURL()); } catch(NoSuchMethodException | SecurityException | MalformedURLException | IllegalAccessException | IllegalArgumentException | InvocationTargetException ex){ throw new MojoExecutionException("Error, could not add URL to system classloader", ex); } } Log.setLogger(new Log.Logger(verbose)); this.packagerLib = new PackagerLib(); } return this.packagerLib; } protected String getEnvironmentRelativeExecutablePath() { if( useEnvironmentRelativeExecutables ){ return ""; } String jrePath = System.getProperty("java.home"); String jdkPath = jrePath + File.separator + ".." + File.separator + "bin" + File.separator; return jdkPath; } protected void copyRecursive(Path sourceFolder, Path targetFolder) throws IOException { Files.walkFileTree(sourceFolder, new FileVisitor() { @Override public FileVisitResult preVisitDirectory(Path subfolder, BasicFileAttributes attrs) throws IOException { // do create subfolder (if needed) Files.createDirectories(targetFolder.resolve(sourceFolder.relativize(subfolder))); return FileVisitResult.CONTINUE; } @Override public FileVisitResult visitFile(Path sourceFile, BasicFileAttributes attrs) throws IOException { // do copy, and replace, as the resource might already be existing Files.copy(sourceFile, targetFolder.resolve(sourceFolder.relativize(sourceFile)), StandardCopyOption.REPLACE_EXISTING, StandardCopyOption.COPY_ATTRIBUTES); return FileVisitResult.CONTINUE; } @Override public FileVisitResult visitFileFailed(Path source, IOException ioe) throws IOException { // don't fail, just inform user getLog().warn(String.format("Couldn't copy resource %s with reason %s", source.toString(), ioe.getLocalizedMessage())); return FileVisitResult.CONTINUE; } @Override public FileVisitResult postVisitDirectory(Path source, IOException ioe) throws IOException { // nothing to do here return FileVisitResult.CONTINUE; } }); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy