Skip to content

Commit

Permalink
Port to DGT and latest TwoConfig changes
Browse files Browse the repository at this point in the history
  • Loading branch information
Deftu committed Nov 21, 2024
1 parent adf912a commit 5e92851
Show file tree
Hide file tree
Showing 15 changed files with 153 additions and 270 deletions.
251 changes: 68 additions & 183 deletions build.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,93 +1,76 @@
@file:Suppress("UnstableApiUsage", "PropertyName")

import org.polyfrost.gradle.util.noServerRunConfigs
import com.github.jengelman.gradle.plugins.shadow.tasks.ShadowJar
import dev.deftu.gradle.utils.GameSide

// Adds support for kotlin, and adds the Polyfrost Gradle Toolkit
// which we use to prepare the environment.
plugins {
kotlin("jvm")
id("org.polyfrost.multi-version")
id("org.polyfrost.defaults.repo")
id("org.polyfrost.defaults.java")
id("org.polyfrost.defaults.loom")
id("com.github.johnrengelman.shadow")
id("net.kyori.blossom") version "1.3.2"
id("signing")
java
kotlin("jvm")
id("dev.deftu.gradle.multiversion")
id("dev.deftu.gradle.tools")
id("dev.deftu.gradle.tools.resources")
id("dev.deftu.gradle.tools.bloom")
id("dev.deftu.gradle.tools.shadow")
id("dev.deftu.gradle.tools.minecraft.loom")
}

// Gets the mod name, version and id from the `gradle.properties` file.
val mod_name: String by project
val mod_version: String by project
val mod_id: String by project
val mod_archives_name: String by project

val accessTransformerName = "patcher1${platform.mcMinor}_at.cfg"
val accessTransformerName = "patcher1${mcData.version.minor}_at.cfg"

// Sets up the variables for when we preprocess to other Minecraft versions.
preprocess {
vars.put("MODERN", if (project.platform.mcMinor >= 16) 1 else 0)
vars.put("MODERN", if (mcData.version.minor >= 16) 1 else 0)
}

// Replaces the variables in `ExampleMod.java` to the ones specified in `gradle.properties`.
blossom {
replaceToken("@VER@", mod_version)
replaceToken("@NAME@", mod_name)
replaceToken("@ID@", mod_id)
}
//if (project.platform.isLegacyForge) {
// runConfigs {
// "client" {
// property("patcher.debugBytecode", "true")
// property("mixin.debug.verbose", "true")
// property("mixin.debug.export", "true")
// property("mixin.dumpTargetOnFailure", "true")
// property("fml.coreMods.load", "club.sk1er.patcher.tweaker.PatcherTweaker")
// programArgs("--tweakClass", "org.polyfrost.oneconfig.internal.legacy.OneConfigTweaker")
// programArgs("--tweakClass", "org.spongepowered.asm.launch.MixinTweaker")
// property("mixin.debug.export", "true")
// programArgs("--mixin", "mixins.${mod_id}.json")
// }
// }
//}

//if (project.platform.isForge) {
// forge {
// accessTransformer(rootProject.file("src/main/resources/$accessTransformerName"))
// mixinConfig("mixins.${mod_id}.json")
// }
//}

toolkitLoomHelper {
useOneConfig(mcData, "commands", "config", "config-impl", "events", "internal", "ui")
useDevAuth()

disableRunConfigs(GameSide.SERVER)

if (!mcData.isNeoForge) {
useMixinRefMap(modData.id)
}

// Sets the mod version to the one specified in `gradle.properties`. Make sure to change this following semver!
version = mod_version
// Sets the group, make sure to change this to your own. It can be a website you own backwards or your GitHub username.
// e.g. com.github.<your username> or com.<your domain>
group = "club.sk1er"
if (mcData.isLegacyForge) {
useTweaker("org.polyfrost.oneconfig.loader.stage0.LaunchWrapperTweaker", GameSide.CLIENT)
useForgeMixin(modData.id) // Configures the mixins if we are building for forge, useful for when we are dealing with cross-platform projects.

// Sets the name of the output jar (the one you put in your mods folder and send to other people)
// It outputs all versions of the mod into the `build` directory.
base {
archivesName.set("$mod_archives_name-$platform")
useProperty("patcher.debugBytecode", "true", GameSide.CLIENT)
useProperty("mixin.debug.verbose", "true", GameSide.CLIENT)
useProperty("mixin.debug.export", "true", GameSide.CLIENT)
useProperty("mixin.dumpTargetOnFailure", "true", GameSide.CLIENT)
useProperty("fml.coreMods.load", "club.sk1er.patcher.tweaker.PatcherTweaker", GameSide.CLIENT)
}
}

// Configures the Polyfrost Loom, our plugin fork to easily set up the programming environment.
loom {
// Removes the server configs from IntelliJ IDEA, leaving only client runs.
// If you're developing a server-side mod, you can remove this line.
noServerRunConfigs()

// Adds the tweak class if we are building legacy version of forge as per the documentation (https://docs.polyfrost.org)
if (project.platform.isLegacyForge) {
runConfigs {
"client" {
property("patcher.debugBytecode", "true")
property("mixin.debug.verbose", "true")
property("mixin.debug.export", "true")
property("mixin.dumpTargetOnFailure", "true")
property("fml.coreMods.load", "club.sk1er.patcher.tweaker.PatcherTweaker")
programArgs("--tweakClass", "org.polyfrost.oneconfig.internal.legacy.OneConfigTweaker")
programArgs("--tweakClass", "org.spongepowered.asm.launch.MixinTweaker")
property("mixin.debug.export", "true")
programArgs("--mixin", "mixins.${mod_id}.json")
}
}
}
// Configures the mixins if we are building for forge, useful for when we are dealing with cross-platform projects.
if (project.platform.isForge) {
if (mcData.isForge) {
loom {
forge {
accessTransformer(rootProject.file("src/main/resources/$accessTransformerName"))
mixinConfig("mixins.${mod_id}.json")
}
}
// Configures the name of the mixin "refmap" using an experimental loom api.
mixin.defaultRefmapName.set("mixins.${mod_id}.refmap.json")
}

// Creates the shade/shadow configuration, so we can include libraries inside our mod, rather than having to add them separately.
val shade: Configuration by configurations.creating {
configurations.implementation.get().extendsFrom(this)
}
val modShade: Configuration by configurations.creating {
configurations.modImplementation.get().extendsFrom(this)
}

// Configures the output directory for when building from the `src/resources` directory.
Expand All @@ -100,41 +83,24 @@ sourceSets {
}
}

// Adds the Polyfrost maven repository so that we can get the libraries necessary to develop the mod.
repositories {
maven("https://repo.polyfrost.org/snapshots")
maven("https://repo.polyfrost.org/releases")
}

// Configures the libraries/dependencies for your mod.
dependencies {
// Adds the OneConfig library, so we can develop with it.
val oneconfig = "1.0.0-alpha.21"
implementation("org.polyfrost.oneconfig:config-impl:$oneconfig")
implementation("org.polyfrost.oneconfig:commands:$oneconfig")
implementation("org.polyfrost.oneconfig:events:$oneconfig")
implementation("org.polyfrost.oneconfig:ui:$oneconfig")
implementation("org.polyfrost.oneconfig:internal:$oneconfig")
modImplementation("org.polyfrost.oneconfig:$platform:$oneconfig")

modShade("org.polyfrost:elementa-$platform:562") {
modImplementation(shade("org.polyfrost:elementa-$mcData:562") {
isTransitive = false
}
})

shade("com.github.ben-manes.caffeine:caffeine:2.9.3")
implementation(shade("com.github.ben-manes.caffeine:caffeine:2.9.3")!!)

shade("com.github.videogame-hacker:Koffee:88ba1b0") {
implementation(shade("com.github.videogame-hacker:Koffee:88ba1b0") {
isTransitive = false
}
})

if (platform.mcMinor < 12) {
shade("it.unimi.dsi:fastutil:8.5.13")
if (mcData.version.minor < 12) {
implementation(shade("it.unimi.dsi:fastutil:8.5.13")!!)
}

modRuntimeOnly("me.djtheredstoner:DevAuth-${if (platform.isFabric) "fabric" else if (platform.isLegacyForge) "forge-legacy" else "forge-latest"}:1.2.0")

// If we are building for legacy forge, includes the launch wrapper with `shade` as we configured earlier.
if (platform.isLegacyForge) {
if (mcData.isLegacyForge) {
compileOnly("org.spongepowered:mixin:0.7.11-SNAPSHOT")
//todo fix with V1
//modImplementation("org.polyfrost:legacy-crafty-crashes:1.0.0") {
Expand All @@ -144,105 +110,24 @@ dependencies {
}

tasks {

compileKotlin {
kotlinOptions {
freeCompilerArgs += listOf("-Xopt-in=kotlin.RequiresOptIn", "-Xno-param-assertions", "-Xjvm-default=all-compatibility")
}
}

// Processes the `src/resources/mcmod.info or fabric.mod.json` and replaces
// the mod id, name and version with the ones in `gradle.properties`
processResources {
inputs.property("id", mod_id)
inputs.property("name", mod_name)
val java = if (project.platform.mcMinor >= 18) {
17 // If we are playing on version 1.18, set the java version to 17
} else {
// Else if we are playing on version 1.17, use java 16.
if (project.platform.mcMinor == 17)
16
else
8 // For all previous versions, we **need** java 8 (for Forge support).
}
val compatLevel = "JAVA_${java}"
inputs.property("java", java)
inputs.property("java_level", compatLevel)
inputs.property("version", mod_version)
inputs.property("mcVersionStr", project.platform.mcVersionStr)
filesMatching(listOf("mcmod.info", "mixins.${mod_id}.json", "mods.toml")) {
expand(
mapOf(
"id" to mod_id,
"name" to mod_name,
"java" to java,
"java_level" to compatLevel,
"version" to mod_version,
"mcVersionStr" to project.platform.mcVersionStr
)
)
}
filesMatching("fabric.mod.json") {
expand(
mapOf(
"id" to mod_id,
"name" to mod_name,
"java" to java,
"java_level" to compatLevel,
"version" to mod_version,
"mcVersionStr" to project.platform.mcVersionStr.substringBeforeLast(".") + ".x"
)
)
}
rename("(.+_at.cfg)", "META-INF/$1")
}

// Configures the resources to include if we are building for forge or fabric.
withType(Jar::class.java) {
if (project.platform.isFabric) {
exclude("mcmod.info", "mods.toml")
} else {
exclude("fabric.mod.json")
if (project.platform.isLegacyForge) {
exclude("mods.toml")
} else {
exclude("mcmod.info")
}
}
}

// Configures our shadow/shade configuration, so we can
// include some dependencies within our mod jar file.
named<ShadowJar>("shadowJar") {
archiveClassifier.set("dev") // TODO: machete gets confused by the `dev` prefix.
configurations = listOf(shade, modShade)
duplicatesStrategy = DuplicatesStrategy.EXCLUDE

relocate("com.github.benmanes", "club.sk1er.patcher.libs")
}

remapJar {
inputFile.set(shadowJar.get().archiveFile)
archiveClassifier.set("")
}

jar {
// Sets the jar manifest attributes.
if (platform.isLegacyForge) {
if (mcData.isLegacyForge) {
manifest.attributes += mapOf(
"FMLCorePlugin" to "club.sk1er.patcher.tweaker.PatcherTweaker",
"ModSide" to "CLIENT", // We aren't developing a server-side mod, so this is fine.
"FMLAT" to accessTransformerName,
"FMLCorePluginContainsFMLMod" to "Yes, yes it does",
"Main-Class" to "club.sk1er.container.ContainerMessage",
"ForceLoadAsMod" to true, // We want to load this jar as a mod, so we force Forge to do so.
"TweakOrder" to "0", // Makes sure that the OneConfig launch wrapper is loaded as soon as possible.
"MixinConfigs" to "mixins.${mod_id}.json", // We want to use our mixin configuration, so we specify it here.
"TweakClass" to "cc.polyfrost.oneconfig.loader.stage0.LaunchWrapperTweaker" // Loads the OneConfig launch wrapper.
"Main-Class" to "club.sk1er.container.ContainerMessage"
)
}
dependsOn(shadowJar)
archiveClassifier.set("")
enabled = false
}

processResources {
exclude("patcher18_at.cfg")
exclude("patcher112_at.cfg")
}
}
8 changes: 4 additions & 4 deletions gradle.properties
Original file line number Diff line number Diff line change
@@ -1,17 +1,17 @@
# gradle.properties file -- CHANGE THE VALUES STARTING WITH `mod_*` AND REMOVE THIS COMMENT.

# Sets the name of your mod.
mod_name=Patcher
mod.name=Patcher
# Sets the id of your mod that mod loaders use to recognize it.
mod_id=patcher
mod.id=patcher
# Sets the version of your mod.
# normal versions will be "1.x.x"
# betas will be "1.x.x+beta-y" / "1.x.x+branch_beta-y"
# rcs will be 1.x.x+rc-y
# extra branches will be 1.x.x+branch-y
mod_version=1.10.1
mod.version=1.10.1
# Sets the name of the jar file that you put in your 'mods' folder.
mod_archives_name=PolyPatcher
mod.group=club.sk1er

# Gradle Configuration -- DO NOT TOUCH THESE VALUES.
polyfrost.defaults.loom=3
Expand Down
4 changes: 1 addition & 3 deletions root.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
plugins {
kotlin("jvm") version "1.9.10" apply false
id("org.polyfrost.multi-version.root")
id("com.github.johnrengelman.shadow") version "8.1.1" apply false
id("dev.deftu.gradle.multiversion-root")
}

preprocess {
Expand Down
31 changes: 22 additions & 9 deletions settings.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,26 +1,39 @@
@file:Suppress("PropertyName")
import groovy.lang.MissingPropertyException

pluginManagement {
repositories {
// Repositories
maven("https://maven.deftu.dev/releases")
maven("https://maven.fabricmc.net")
maven("https://maven.architectury.dev/")
maven("https://maven.minecraftforge.net")
maven("https://repo.essential.gg/repository/maven-public")
maven("https://server.bbkr.space/artifactory/libs-release/")
maven("https://jitpack.io/")

// Snapshots
maven("https://maven.deftu.dev/snapshots")
mavenLocal()

// Default repositories
gradlePluginPortal()
mavenCentral()
maven("https://repo.polyfrost.org/releases") // Adds the Polyfrost maven repository to get Polyfrost Gradle Toolkit
}

plugins {
val pgtVersion = "0.6.5" // Sets the default versions for Polyfrost Gradle Toolkit
id("org.polyfrost.multi-version.root") version pgtVersion
kotlin("jvm") version("2.0.0")
id("dev.deftu.gradle.multiversion-root") version("2.12.0")
}
}

val mod_name: String by settings

// Configures the root project Gradle name based on the value in `gradle.properties`
rootProject.name = mod_name
val projectName: String = extra["mod.name"]?.toString()
?: throw MissingPropertyException("mod.name has not been set.")
rootProject.name = projectName
rootProject.buildFileName = "root.gradle.kts"

// Adds all of our build target versions to the classpath if we need to add version-specific code.
listOf(
"1.8.9-forge", // Update this if you want to remove/add a version, along with `build.gradle.kts` and `root.gradle.kts`.
"1.8.9-forge",
"1.12.2-forge"
).forEach { version ->
include(":$version")
Expand Down
Loading

0 comments on commit 5e92851

Please sign in to comment.