Skip to content

Latest commit

 

History

History
53 lines (43 loc) · 3.22 KB

File metadata and controls

53 lines (43 loc) · 3.22 KB

Simplified Modern Gradle Template

This is the simplified version of my Modern Gradle Template that suites for using as a GitHub template.

The structure of the template stays the same but less boiler stuff to be deleted.

Features

This template can be used to create new spring/quarkus/micronaut/etc. projects, or to create new libraries. No matter it is single-module or multi-module, it is easy to start with this template.

Advantages:

  1. Centralized version management by version catalog and gradle platform (together cover any version declaration in the main build script, and plugins and dependencies blocks in precompiled script plugins, without any hacks)
  2. Composite build, not buildSrc (Although it doesn't matter anymore since Gradle 8.0)
  3. Composition over Inheritance using mixin plugins and convention plugins to maximize parallel build performance

How to use

  1. Modify the project name rootProject.name in settings.gradle.kts to your own project name.
  2. Add your own mixin plugins and convention plugins, if you want to start from scratch, you can delete all preexisting mixin and convention plugins. Remember to archive centralized version management by adding your own libraries into the version catalog.
    • Tip 1: if you want to use version catalog in the dependencies block in precompiled script plugins (mixin or convention plugins), put them in the constraints block in the dev-version-constraints platform. Then in precompiled script plugins, declare the library dependency without the version (e.g. implementation("org.springframework.boot:spring-boot-starter")). This works for Maven bom and Gradle platform as well.
    • Tip 2: if you want to use version catalog in the plugins block in precompiled script plugins (mixin or convention plugins), you instead let the build.gradle.kts (is also the one with kotlin-dsl applied) that build the precompiled script plugin applies the version catalog. Then in precompiled script plugins, declare the library dependency without the version ((e.g. id("org.springframework.boot"))
    • Tip 3: there is a little kotlin-jvm mixin plugin that demonstrates the above two tips.
  3. Delete the sample submodules beginning with sample-, and start adding your own submodules. Or you can reuse them by renaming them as it only contains a single build.gradle.kts file.
  4. (Optional) The template contains a renovate bot config file to automatically update dependencies in the version catalog. You can delete it if you don't need it.

TODO