A Gradle plugin to simplify working with LWJGL 3.
Note
The documentation of this plugin is written in Gradle's Kotlin DSL. The plugin can also be used with Groovy build scripts and all concepts still apply but the exact syntax may differ.
plugins {
id("com.osmerion.lwjgl3") version "0.5.0"
}
The plugin introduces the concept of "targets" to enable using multiple different LWJGL setups (different versions, modules, etc.) within a single Gradle project. In the following example, a target is registered and linked to the appropriate configurations.
val lwjgl3MainTarget = targets.register("main")
configurations.named("implementation") {
extendsFrom(lwjgl3MainTarget.get().libConfiguration.get())
}
configurations.named("runtimeOnly") {
extendsFrom(lwjgl3MainTarget.get().nativesConfiguration.get())
}
The configuration libConfiguration
contains all Java library dependency
artifacts and the configuration nativeConfiguration
includes the artifacts
containing the native libraries for LWJGL for the current host.
Important
By default, a main
target as defined above is automatically registered when
the org.gradle.java
plugin is detected. To disable this behavior, set the
property com.osmerion.lwjgl3.implicit-target
to false
.
LWJGL consists of many modules which contain bindings to different native libraries. Modules can be added to a target as follows:
lwjgl3 {
targets.named("main") {
modules.add(Lwjgl.Core)
}
}
Predefined accessors for known LWJGL modules are available in the Lwjgl
class.
In addition to using the predefined module accessors, it is also possible to use custom modules. This can be useful when working with forked versions of LWJGL or for new modules for which no predefined accessors are available yet.
lwjgl3 {
targets.named("main") {
modules.add("lwjgl-glfw")
}
}
As LWJGL provides bindings to native libraries, it is also necessary to declare which native platforms should be included in a target. Several functions are available for LWJGL targets and can be used to include a predefined platform. E.g.:
lwjgl3 {
targets.named("main") {
windowsX64()
}
}
The following predefined platforms are available:
freebsdX64
linuxARM32
,linuxARM64
,linuxPPC64LE
,linuxRISCV64
,linuxX64
macosARM64
,macosX64
windowsARM64
,windowsX64
,windowsX86
To ease development and testing, by default, the plugin automatically registers
an implicit platform for the build host. This platform can be identified using
the isImplicitHostPlatform
property. If the host is not a supported platform,
no implicit platform is registered.
The isImplicitHostPlatform
property should be respected to avoid creating
distributions (or similar) for the automatically added platform.
Important
The isImplicitHostPlatform
property should be respected to avoid creating
distributions (or similar) for the automatically added platform. To disable
its creation, set the property com.osmerion.lwjgl3.implicit-host-platform
to
false
.
Additionally, custom platforms can be declared using the platform
function.
This is mostly useful when porting LWJGL to new platforms or when the plugin has
not been updated yet to include new predefined functions.
lwjgl3 {
targets.named("main") {
platform(name = "FreeBSDX64") {
artifactClassifier.set("natives-freebsd")
match {
os.set(OperatingSystem.FreeBSD)
arch.set(Architecture.X86_64)
}
}
}
}
The plugin can further be customized to use a different version of LWJGL by
configuring the version
property of a target. Similarly, the group
property
can be used to configure the group name portion of the GAV coordinates for the
LWJGL artifacts.
lwjgl3 {
targets.named("main") {
group.set("org.lwjgl")
version.set("3.3.5")
}
}
LWJGL3 Gradle Plugin | Supported Gradle versions |
---|---|
0.4.0 | 8.0+ |
0.1.0 | 7.6+ |
LWJGL3 Gradle Plugin | Default LWJGL version |
---|---|
0.6.0 | 3.3.6 |
0.5.0 | 3.3.5 |
0.3.0 | 3.3.4 |
0.2.0 | 3.3.3 |
0.1.0 | 3.3.2 |
This project uses Gradle's toolchain support to detect and select the JDKs required to run the build. Please refer to the build scripts to find out which toolchains are requested.
An installed JDK 1.8 (or later) is required to use Gradle.
Once the setup is complete, invoke the respective Gradle tasks using the following command on Unix/macOS:
./gradlew <tasks>
or the following command on Windows:
gradlew <tasks>
Important Gradle tasks to remember are:
clean
- clean build resultsbuild
- assemble and test the Java librarypublishToMavenLocal
- build and install all public artifacts to the local maven repository
Additionally tasks
may be used to print a list of all available tasks.
This plugin is available under the terms of the 3-Clause BSD license.
Copyright (c) 2021-2025 Leon Linhart,
All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:
1. Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
3. Neither the name of the copyright holder nor the names of its contributors
may be used to endorse or promote products derived from this software
without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.