- Before submitting a bug report, verify that it is not caused by the libGDX framework itself.
- Feel free to create issues or start discussions with feature requests and questions about the libraries. Issues and discussions are among the fastest way to contact the developers.
- The latest changes are always in the
develop
branch.master
branch always matches the latest stable release. Make sure to checkoutdevelop
branch before starting your work and setdevelop
as the target branch before creating a pull request. - Include issue or pull request IDs in related commit messages. This makes it easier to locate more information about the changes. For example:
Kotlin version update. #250
- Format your code changes with the
gradle format
task. We are relying on automatic formatting performed with ktlint. Rungradle linterIdeSetup
to apply formatter changes to your IntelliJ project. - Follow our file naming convention:
- Files with a single class: file name should match class name. E.g.
FileLoader.kt
. - Others: files with extension methods, top-level functions, utilities or multiple classes should use camel case
nouns starting with a lower-cased letter. Should generally be in plural form. E.g.
fileLoaders.kt
.
- Files with a single class: file name should match class name. E.g.
- Make sure to include unit tests of your code. Test names should use the
`backtick method name`
syntax. JUnit and Spek can be used to write tests, although JUnit is encouraged for its commonness. Use Mockito-Kotlin for mocking. - In case of a larger pull request, make sure to link it to an existing issue or create a corresponding issue first. Major API changes or new modules should be discussed with the maintainers. Skipping the issue will not get your pull request rejected outright, but note that major changes without approval might require a rewrite.
- All notable changes should be added to the changelog with an appropriate label:
- [FEATURE] - a new functionality.
- [CHANGE] - an API breaking change.
- [UPDATE] - an update of one of the major dependencies.
- [FIX] - a bug fix.
- [MISC] - other changes (e.g. related to documentation or the project itself).
- Most libraries list all features in the
README.md
files to ease their usage. When adding a new feature, please check theREADME.md
file of the module, and add description of your change when appropriate. Any major feature should include a usage example in the module guide. Make sure to add all the necessary imports in the usage examples inREADME.md
files to make it easier to try them out.
git clone https://github.com/libktx/ktx.git
cd ktx
git checkout develop
The project itself is managed by Gradle. Gradle wrapper is included, but you can use a local
Gradle installation - scripts should be compatible with Gradle 7.+
. Gradle projects are handled out of the box by
IntelliJ, so KTX should be easy to import.
Some useful Gradle tasks include:
build install
- builds the libraries archives and pushes them to Maven Local. Useful for local tests.format
- formats all Kotlin source files.linterIdeSetup
- modifies local IntelliJ project setup for consistency withktlint
formatting.check
- runs all tests in all projects.clean
- removes thebuild
directories, which forces rebuilds of the modules.distZip
- prepares a zip archive with all jars inbuild/distributions
folder. Useful for releases.publish
- pushes the archives to Maven Central or the snapshot repository, depending on the version. Requires completegradle.properties
with archive signing and Sonatype logging data.closeAndReleaseRepository
- closes and releases the Nexus repository. Should be run afterpublish
in case of a non-snapshot upload to Maven Central. Might fail at times on the release task; runningreleaseRepository
separately should fix the issue.
- Create a folder matching module name in root of the repository. Modules should generally be named with a single word.
When multiple words are necessary, use a single dash (
-
) as the word separator. - Add folder name to
settings.gradle.kts
file. This will also serve as the project identifier that you use inbuild.gradle
scripts and to run individual Gradle tasks (e.g.gradle actors:test
). - Create
src/main/kotlin
andsrc/test/kotlin
directories in your module folder. They will be automatically marked as source thanks to Gradle. You should also create package structure matchingktx/your/module
in each source folder. - Add
gradle.properties
file with the following properties:
projectName=ktx-your-module
projectDesc=Description of your module as it will appear in Maven Central.
- Add a
build.gradle.kts
file. It should contain dependencies specific to your module. If there are none, you can leave it empty. By addingimport ktx.*
at the top of this file, you will be able to access the versions of major dependencies of the modules as defined in thebuildSrc
directory. - Add a
README.md
file describing your module. Refer to otherREADME.md
files for examples.README.md
files can consist of the following sections:- General description - in a single sentence, what problem does the module solve?
- Motivation - why was the module created?
- Guide - what features does the module provide? Does it require additional setup?
- Usage examples - how to use the module?
- Synergy - is the module complemented by any other KTX libraries?
- Alternatives - are there any other libraries or modules that can be used instead?
- Additional documentation - are there any other guides or articles on the topic?
- Add Maven Central badge to the top of the
README.md
to ease inclusion of the library:
[![Maven Central](https://img.shields.io/maven-central/v/io.github.libktx/ktx-your-module.svg)](https://search.maven.org/artifact/io.github.libktx/ktx-your-module)
- Your final module structure should roughly match this schema:
> your-module/
> src/
> main/kotlin/ktx/your/module/
- yourModule.kt
> test/kotlin/ktx/your/module/
- yourModuleTest.kt
- build.gradle.kts
- gradle.properties
- README.md
- Include the module in the listing in the main
README.md
file.
The following sections are for the maintainers of the repository.
Kotlin and plugin versions are stored in the gradle.properties file, while module dependencies
versions are stored with the Versions.kt
file. Snapshot releases
should keep all the dependencies (outside of testing scope) up-to-date. Major dependencies include:
- libGDX: update
gdxVersion
in the versions file and libGDX version in the tag on the top of the README.md file. Note that updating libGDX also affects the KTX version and milestones, so make sure to update the version.txt and milestones as well. - Kotlin: update the
kotlinVersion
in the properties file and the Kotlin tag in the README.md. - Kotlin Coroutines: update
kotlinCoroutinesVersion
in the versions file and the tag in thektx-async
README.md. - Gradle: run
gradle wrapper --distribution-type all
in the root project folder. Make sure that the Gradle wrapper properties file points theall
Gradle release underdistributionUrl
rather than just the binaries (bin
). Note that you do not have to install the corresponding Gradle version locally: instead, you can update the version ingradle-wrapper.properties
first, and then run./gradlew wrapper
to update the Gradle wrapper scripts and configuration files. - VisUI: update
visUiVersion
in the versions file and VisUI version in the tag on the top of the vis/README.md file. - Ashley: update
ashleyVersion
in the versions file and Ashley version in the tag on the top of the ashley/README.md file. - Artemis-odb: update
artemisOdbVersion
in the versions file and Artemis-odb version in the tag on the top of the artemis/README.md file. - gdxAI: update
gdxAiVersion
in the versions file and gdxAI version in the tag on the top of the ai/README.md file.
All the major dependencies updates should be added to the changelog.
- Create a new issue on GitHub. Include the number of the issue in commit messages of all commits related to the release.
Apply
dev
label and milestone corresponding to the libGDX version. An example can be found here. - Change
libVersion
setting in theversion.txt
. KTX uses the same versioning schema as libGDX (mimicking the libGDX version that it was compiled against) with a suffix depending on the version status. - Create a pull request from the
develop
branch to themaster
branch. Review and merge the changes to themaster
branch. - Checkout the
master
branch. Fetch the latest changes. - Run
gradle build publish closeAndReleaseRepository
to push artifacts to Maven Central. Note that the Maven plugin has its issues and might fail with an error, but usually the release will be successful. You can check if the staging repository was properly close, promoted and released at Nexus Repository Manager. - Run
gradle distZip
to prepare an archive with KTX sources, compiled binary and documentation. - Upload the archive to releases section. The tag should be made from the
master
branch and its name should match the released version. Name of the release should matchKTX $libVersion
. Add a short release summary and copy the latest changelog entries to the release description. - If there are any known issues with the previous or current versions, please attach additional Known issues: section
with the following labels:
- [BUG] - a known bug in the release that is or will be fixed in the following versions.
- [INCOMPATIBILITY] - incompatibility with one of the previously supported or currently released versions of one of the major dependencies.
- [REMOVAL] - temporary or permanent removal of a major feature (e.g. disabling a module for a single release).
- Checkout the
develop
branch. - Change
libVersion
setting in theversion.txt
to the next snapshot release. The name should match the used libGDX version followed by the-SNAPSHOT
suffix.
- Make sure the
version.txt
ends with the-SNAPSHOT
suffix and matches the libGDX version that the library was compiled against. - Run
gradle build uploadSnapshot
to push artifacts to Sonatype snapshots repository. This task will do nothing if the current version is not a snapshot to avoid accidentally pushing a stable release.
Note that snapshots are automatically uploaded to Maven Central (OSS Sonatype)
snapshots repository after pushing
to the develop
branch.
Tasks automated with GitHub actions:
- build - compiles and tests all KTX modules. Triggered by pushing and setting up pull requests
to
master
anddevelop
branches. - upload-snapshot - compiles all KTX modules and uploads a new snapshot release.
Triggered by pushing to the
develop
branch. - publish-documentation - builds and replaces the Dokka documentation published
to the official website. Triggered by pushing to the
master
branch, which is generally only done before stable releases.
- publish-project-samples - generates sample projects with
gdx-liftoff based on the latest KTX version from the
master
branch, and pushes them to the ktx-sample-project and ktx-sample-web-project repositories. Triggered by creating new release tags.