An example of how to create a custom build system based on Gradle
Custom Gradle-based Build System
This is an example of how to create a custom build system based on Gradle. It only uses the Gradle core without any existing plugins.
The Build System
The build system is implemented as a Gradle Plugin. It can be used to develop Games for the playdate handheld game system that are based on existing 1-bit picture assets from Kenney. This repository contains a simple picture matching game where you have to find a picture in a list using the Crank to scroll through the list. The build system itself could be used to develop other picture-based games using Kenney’s assets.
That’s why the build system (the Gradle plugin) is called playdate-picture-game. It automates the following tasks:
- Selecting a Playdate version that is downloaded and installed (only works on Mac right now)
- Selecting an asset pack from Kenney’s website that is downloaded and processed to match the playdate’s image table format
- Combining your sources and the image so that they fit the playdate project structure and then calling the playdate compiler
Advantage of using Gradle
By doing this setup in Gradle, you automatically get:
- Downloading and caching of dependencies (SDK, assets)
- Incremental building (only tasks for which things change are executed)
- Local Build Cache
- Remote Build Cache
- Parallel execution
- Build Scans to analyse the build
Usage
- Build everything with
./gradlew :compilePlaydate
(see limitations below if you get an error) - You can add
--console=plain
and/or--scan
to see what’s happening in the build - Run the build multiple times to see incremental building and caching in action
- Adjust the dependencies – asset pack, SDK version – in build.gradle.kts
- Adjust the game source in source/main.lua
- Run the game in the playdate simulator (free to use, part of SDK) by starting
build/dist/playdate-sprite-match.pdx
- Explore the Build System Implementation (Gradle Plugin Implementation) in gradle/playdate-picture-game/src/main/kotlin (Check my Understanding Gradle videos for information on the Gradle concepts used)
Limitations of this example
The installPlaydateSdk
task currently only work on Mac (OS X) and needs to use sudo
to call the installer
tool.
It only works if you run as administrator account with the allowance to run sudo
without typing your password again.
You can configure that using visudo
. If you don’t want to or can’t do that you can still see the example in action if you remove the sudo installer call from PlaydateSdkInstall.kt and install the SDK manually.
The rest of the example still works.