Skip to content

xzel23/badass-jlink-plugin

 
 

Repository files navigation

PRs Welcome License Build Status

Badass JLink Plugin

NOTE: This is a fork of the original Badass-Jlink-Plugin that is patched to support newer Java releases and other fixes not yet available with the original plugin.
Changes in this fork

3.1.0

Base line for this version is the upstream 3.1.0 plugin.

In addition, these changes are included:

  • support parsing annotated module declarations, this makes it possible to use JSpecify @NullMarked on the module declaration.

3.0.1-patch-1

  • fix secondary Launcher fails in Kotlin DSL (issue in original repository: #244)
  • update ASM for compatibility with newer JDK versions
  • fix building the plugin on Windows ARM:
    • disable Gradle toolchains (not yet working on Windows ARM)
    • disable JavaFX tests on Windows ARM because the JavaFX plugin is not yet compatible with the platform. You can still build JavaFX jlink applications on Windows ARM if you do not use the JavaFX plugin (use a local installation of JavaFX or a JDK that is prebuilt with JavaFX support or manually add the correct JavaFX dependencies).
How to build

Make sure your environment is set to use JDK 17 (I have disabled toolchains because of missing support on Windows ARM)

How to use

Change the plugin ID from org.beryx.jlink to com.dua3.gradle.jlink in your Gradle build files.

The following is the content of the original README.

NOTE: Looking for co-maintainers - see this issue.

Using this Gradle plugin you can create a custom runtime image of your modular application with minimal effort, even if it depends on automatic modules. The plugin also lets you create an application installer with the jpackage tool introduced in Java 14 (see fxgl-sliding-puzzle for a usage example).

💡 For non-modular applications use the Badass-Runtime plugin.

Badass-JLink exposes an extension with the name jlink to let you configure various aspects of its operation. A simple example configuration is shown below:

jlink {
    options = ['--strip-debug', '--compress', '2', '--no-header-files', '--no-man-pages']
    launcher{
        name = 'hello'
        jvmArgs = ['-Dlog4j.configurationFile=./log4j2.xml']
    }
}

This is a complex plugin. Please read the documentation before using it.

The following projects illustrate how to use this plugin to create custom runtime images:

See the list of all releases if you use an older version of this plugin.

About

Create a custom runtime image of your modular application

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Groovy 96.5%
  • Java 2.9%
  • Other 0.6%