import dev.ithundxr.silk.ChangelogText plugins { id "idea" id "eclipse" id "maven-publish" id "net.neoforged.moddev" version "2.0.74" id "me.modmuss50.mod-publish-plugin" version "0.8.3" id "dev.ithundxr.silk" version "0.11.15" id "net.kyori.blossom" version "2.1.0" // https://github.com/KyoriPowered/blossom id "org.jetbrains.gradle.plugin.idea-ext" version "1.1.8" // https://github.com/JetBrains/gradle-idea-ext-plugin } apply from: './gradle/java.gradle' boolean dev = System.getenv('RELEASE') == null || System.getenv('RELEASE').equals('false') ext.buildNumber = System.getenv('BUILD_NUMBER') String gitHash = "\"${calculateGitHash() + (hasUnstaged() ? "-modified" : "")}\"" base { archivesName = "create-$minecraft_version" group = "com.simibubi.create" version = mod_version + (dev && buildNumber != null ? "-${buildNumber}" : '') } boolean inMultiModWorkspace = rootProject.hasProperty('multiModWorkspace.enabled') boolean ponderInWorkspace = rootProject.hasProperty('multiModWorkspace.ponder') if (ponderInWorkspace) { evaluationDependsOn(":ponder:NeoForge") } project.logger.lifecycle("MultiModWorkspace ${inMultiModWorkspace ? 'enabled' : 'disabled'} for project ${project.name}.") project.logger.lifecycle("Dependencies included in Workspace: [Ponder: ${ponderInWorkspace}]") println "Java: ${System.getProperty 'java.version'}, JVM: ${System.getProperty 'java.vm.version'} (${System.getProperty 'java.vendor'}), Arch: ${System.getProperty 'os.arch'}" idea { module { downloadJavadoc = true downloadSources = true } } neoForge { version = project.neo_version accessTransformers = project.files('src/main/resources/META-INF/accesstransformer.cfg') parchment { minecraftVersion = project.parchment_minecraft_version mappingsVersion = project.parchment_version } mods { "${mod_id}" { sourceSet(sourceSets.main) } if (ponderInWorkspace) { ponder { sourceSet(project(":ponder:Common").sourceSets.main) sourceSet(project(":ponder:NeoForge").sourceSets.main) } } } runs { configureEach { systemProperty 'forge.logging.markers', 'REGISTRIES' jvmArguments = ["-XX:+IgnoreUnrecognizedVMOptions", "-XX:+AllowEnhancedClassRedefinition"] //jvmArgs("-XX:-OmitStackTraceInFastThrow") // uncomment when you get exceptions with null messages etc //jvmArgs '-XX:+UnlockCommercialFeatures' // uncomment for profiling systemProperty 'mixin.debug.verbose', 'true' systemProperty 'mixin.debug.export', 'true' logLevel = org.slf4j.event.Level.DEBUG } client { client() // Comma-separated list of namespaces to load gametests from. Empty = all namespaces. systemProperty 'neoforge.enabledGameTestNamespaces', project.mod_id } server { server() gameDirectory = project.file('run/server') programArgument '--nogui' systemProperty 'neoforge.enabledGameTestNamespaces', project.mod_id } data { data() programArguments.addAll('--mod', project.mod_id, '--all', '--output', file('src/generated/resources/').getAbsolutePath(), '--existing', file('src/main/resources/').getAbsolutePath()) } gameTestServer { type = "gameTestServer" systemProperty 'neoforge.enabledGameTestNamespaces', project.mod_id } } } configurations { runtimeClasspath.extendsFrom localRuntime } repositories { maven { url = "https://maven.createmod.net" } // Ponder, Flywheel maven { url = "https://mvn.devos.one/snapshots" } // Registrate maven { url = "https://maven.blamejared.com" } // JEI, Vazkii's Mods maven { url = "https://harleyoconnor.com/maven" } // Dynamic Trees maven { url = "https://maven.theillusivec4.top/" } // Curios API maven { url = "https://maven.squiddev.cc" } // CC: Tweaked maven { url = "https://www.cursemaven.com" } maven { url = "https://api.modrinth.com/maven" } maven { url = "https://maven.saps.dev/releases" } // FTB Mods maven { url = "https://maven.architectury.dev" } // Arch API maven { url = "https://raw.githubusercontent.com/Fuzss/modresources/main/maven" } // NeoForge config api port, needed by ponder maven { url = "https://jm.gserv.me/repository/maven-public" // JourneyMap content { includeGroup "info.journeymap" includeGroup "mysticdrew" } } } dependencies { jarJar(implementation("com.tterrag.registrate:Registrate:${registrate_version}")) jarJar("dev.engine-room.flywheel:flywheel-neoforge-${flywheel_minecraft_version}:${flywheel_version}") { version { strictly "[1.0,2.0)" } } compileOnly("dev.engine-room.flywheel:flywheel-neoforge-api-${flywheel_minecraft_version}:${flywheel_version}") runtimeOnly("dev.engine-room.flywheel:flywheel-neoforge-${flywheel_minecraft_version}:${flywheel_version}") runtimeOnly("dev.engine-room.vanillin:vanillin-neoforge-${flywheel_minecraft_version}:${flywheel_version}") if (ponderInWorkspace) { implementation(project(":ponder:Common")) implementation(project(":ponder:NeoForge")) } else { implementation("net.createmod.ponder:Ponder-NeoForge-${minecraft_version}:${ponder_version}") } jarJar("net.createmod.ponder:Ponder-NeoForge-${minecraft_version}:${ponder_version}") //compileOnly("mezz.jei:jei-${jei_minecraft_version}-common-api:${jei_version}") //compileOnly("mezz.jei:jei-${jei_minecraft_version}-neoforge-api:${jei_version}") implementation("mezz.jei:jei-${jei_minecraft_version}-neoforge:${jei_version}") compileOnly("top.theillusivec4.curios:curios-neoforge:${curios_version}+${curios_minecraft_version}:api") runtimeOnly("top.theillusivec4.curios:curios-neoforge:${curios_version}+${curios_minecraft_version}") compileOnly("maven.modrinth:sodium:mc${minecraft_version}-${sodium_version}-neoforge") if (cc_tweaked_enable.toBoolean()) { compileOnly("cc.tweaked:cc-tweaked-${cc_tweaked_minecraft_version}-core-api:${cc_tweaked_version}") compileOnly("cc.tweaked:cc-tweaked-${cc_tweaked_minecraft_version}-forge-api:${cc_tweaked_version}") // TODO - Uncomment when cc tweaked supports the api refactors //runtimeOnly("cc.tweaked:cc-tweaked-${cc_tweaked_minecraft_version}-forge:${cc_tweaked_version}") } runtimeOnly("dev.architectury:architectury-neoforge:13.0.8") implementation("dev.ftb.mods:ftb-chunks-neoforge:2101.1.1") implementation("dev.ftb.mods:ftb-teams-neoforge:2101.1.0") implementation("dev.ftb.mods:ftb-library-neoforge:2101.1.3") implementation("maven.modrinth:journeymap:1.21.1-6.0.0-beta.32+neoforge") implementation("info.journeymap:journeymap-api-neoforge:2.0.0-1.21.1-SNAPSHOT") { exclude(group: "curse.maven") // Pulls in a old version of journey map which is for forge } } sourceSets.main { java { if (!cc_tweaked_enable.toBoolean()) { exclude 'com/simibubi/create/compat/computercraft/implementation/**' } } resources { srcDir 'src/generated/resources' exclude '.cache/' } blossom.javaSources { property("version", build_info_mod_version) property("gitCommit", gitHash.toString()) } } processResources { def buildProps = project.properties.clone() // Replaces FML's magic file.jarVersion string with the correct version at build time. buildProps.put('file', [jarVersion: project.version]) filesMatching(['META-INF/mods.toml', 'pack.mcmeta']) { expand buildProps } } compileJava { options.compilerArgs = ['-Xdiags:verbose'] } jar { from('LICENSE') { rename { "${it}_${archivesBaseName}" } } manifest.attributes([ "MixinConfigs": "create.mixins.json", "Git-Hash" : gitHash ]) } tasks.named("sourcesJar") { manifest.attributes([ "Git-Hash": gitHash ]) } var generateModMetadata = tasks.register("generateModMetadata", ProcessResources) { var replaceProperties = [ mod_version : mod_version, mod_id : mod_id, mod_name : mod_name, mod_author : mod_author, mod_description : mod_description, mod_license : mod_license, minecraft_version_range: minecraft_version_range, neo_version_range : neo_version_range, flywheel_version_range : flywheel_version_range, ] inputs.properties replaceProperties expand replaceProperties from "src/main/templates" into "build/generated/sources/modMetadata" } // Include the output of "generateModMetadata" as an input directory for the build // this works with both building through Gradle and the IDE. sourceSets.main.resources.srcDir(generateModMetadata) // To avoid having to run "generateModMetadata" manually, make it run on every project reload neoForge.ideSyncTask(generateModMetadata) publishing { publications { register('mavenJava', MavenPublication) { from components.java } } repositories { if (project.hasProperty("mavenUsername") && project.hasProperty("mavenPassword") && project.hasProperty("mavenURL")) { project.logger.lifecycle("Adding maven from secrets") maven { credentials { username = project.property("mavenUsername") as String password = project.property("mavenPassword") as String } url = URI.create(project.property("mavenURL") as String) } } if (project.hasProperty('mavendir')) { maven { url = mavendir } } } } publishMods { file = jar.archiveFile changelog = ChangelogText.getChangelogText(project).toString() type = STABLE displayName = "$mod_name $minecraft_version $mod_version" modLoaders.add("neoforge") curseforge { accessToken = providers.environmentVariable("CURSEFORGE_TOKEN") projectId = "328085" minecraftVersions.add(minecraft_version) } modrinth { accessToken = providers.environmentVariable("MODRINTH_TOKEN") projectId = "LNytGWDc" minecraftVersions.add(minecraft_version) } } String calculateGitHash() { try { def output = providers.exec { commandLine("git", "rev-parse", "HEAD") } return output.standardOutput.asText.get().trim() } catch (Throwable ignored) { return "unknown" } } boolean hasUnstaged() { try { def output = providers.exec { commandLine("git", "status", "--porcelain") } String result = output.standardOutput.asText.get().replace("/M gradlew(\\.bat)?/", "").trim() if (!result.isEmpty()) println("Found stageable results:\n ${result}\n") return !result.isEmpty() } catch (Throwable ignored) { return false } }