diff --git a/.gitignore b/.gitignore index 34ac734..5e80e0a 100644 --- a/.gitignore +++ b/.gitignore @@ -30,3 +30,9 @@ src/main/resources/mixins.*([!.]).json *.bat *.DS_Store !gradlew.bat +.factorypath +addon.local.gradle +addon.local.gradle.kts +addon.late.local.gradle +addon.late.local.gradle.kts +layout.json diff --git a/build.gradle b/build.gradle index 50c3291..e57a16f 100644 --- a/build.gradle +++ b/build.gradle @@ -1,1610 +1,5 @@ -//version: 1702141377 -/* - DO NOT CHANGE THIS FILE! - Also, you may replace this file at any time if there is an update available. - Please check https://github.com/GTNewHorizons/ExampleMod1.7.10/blob/master/build.gradle for updates. - */ +//version: 1707058017 - -import com.github.jengelman.gradle.plugins.shadow.tasks.ShadowJar -import com.gtnewhorizons.retrofuturagradle.ObfuscationAttribute -import com.gtnewhorizons.retrofuturagradle.mcp.ReobfuscatedJar -import com.gtnewhorizons.retrofuturagradle.minecraft.RunMinecraftTask -import com.gtnewhorizons.retrofuturagradle.util.Distribution -import com.matthewprenger.cursegradle.CurseArtifact -import com.matthewprenger.cursegradle.CurseRelation -import com.modrinth.minotaur.dependencies.ModDependency -import com.modrinth.minotaur.dependencies.VersionDependency -import org.gradle.internal.logging.text.StyledTextOutput.Style -import org.gradle.internal.logging.text.StyledTextOutputFactory -import org.gradle.internal.xml.XmlTransformer -import org.jetbrains.gradle.ext.Application -import org.jetbrains.gradle.ext.Gradle - -import javax.inject.Inject -import java.nio.file.Files -import java.nio.file.Paths -import java.util.concurrent.TimeUnit - -buildscript { - repositories { - maven { - // GTNH RetroFuturaGradle and ASM Fork - name "GTNH Maven" - url "http://jenkins.usrv.eu:8081/nexus/content/groups/public/" - allowInsecureProtocol = true - } - mavenLocal() - } -} plugins { - id 'java-library' - id "org.jetbrains.gradle.plugin.idea-ext" version "1.1.7" - id 'eclipse' - id 'scala' - id 'maven-publish' - id 'org.jetbrains.kotlin.jvm' version '1.8.0' apply false - id 'org.jetbrains.kotlin.kapt' version '1.8.0' apply false - id 'com.google.devtools.ksp' version '1.8.0-1.0.9' apply false - id 'org.ajoberstar.grgit' version '4.1.1' // 4.1.1 is the last jvm8 supporting version, unused, available for addon.gradle - id 'com.github.johnrengelman.shadow' version '8.1.1' apply false - id 'com.palantir.git-version' version '3.0.0' apply false - id 'de.undercouch.download' version '5.4.0' - id 'com.github.gmazzo.buildconfig' version '3.1.0' apply false // Unused, available for addon.gradle - id 'com.diffplug.spotless' version '6.13.0' apply false // 6.13.0 is the last jvm8 supporting version - id 'com.modrinth.minotaur' version '2.+' apply false - id 'com.matthewprenger.cursegradle' version '1.4.0' apply false - id 'com.gtnewhorizons.retrofuturagradle' version '1.3.26' -} - -print("You might want to check out './gradlew :faq' if your build fails.\n") - -boolean settingsupdated = verifySettingsGradle() -settingsupdated = verifyGitAttributes() || settingsupdated -if (settingsupdated) - throw new GradleException("Settings has been updated, please re-run task.") - -// In submodules, .git is a file pointing to the real git dir -if (project.file('.git/HEAD').isFile() || project.file('.git').isFile()) { - apply plugin: 'com.palantir.git-version' -} - -def out = services.get(StyledTextOutputFactory).create('an-output') - -def projectJavaVersion = JavaLanguageVersion.of(8) - -boolean disableSpotless = project.hasProperty("disableSpotless") ? project.disableSpotless.toBoolean() : false -boolean disableCheckstyle = project.hasProperty("disableCheckstyle") ? project.disableCheckstyle.toBoolean() : false - -final String CHECKSTYLE_CONFIG = """ - - - - - - - - - - - -""" - -checkPropertyExists("modName") -checkPropertyExists("modId") -checkPropertyExists("modGroup") -checkPropertyExists("autoUpdateBuildScript") -checkPropertyExists("minecraftVersion") -checkPropertyExists("forgeVersion") -checkPropertyExists("replaceGradleTokenInFile") -checkPropertyExists("gradleTokenVersion") -checkPropertyExists("apiPackage") -checkPropertyExists("accessTransformersFile") -checkPropertyExists("usesMixins") -checkPropertyExists("mixinPlugin") -checkPropertyExists("mixinsPackage") -checkPropertyExists("coreModClass") -checkPropertyExists("containsMixinsAndOrCoreModOnly") -checkPropertyExists("usesShadowedDependencies") -checkPropertyExists("developmentEnvironmentUserName") - -propertyDefaultIfUnset("generateGradleTokenClass", "") -propertyDefaultIfUnset("includeWellKnownRepositories", true) -propertyDefaultIfUnset("noPublishedSources", false) -propertyDefaultIfUnset("usesMixinDebug", project.usesMixins) -propertyDefaultIfUnset("forceEnableMixins", false) -propertyDefaultIfUnset("channel", "stable") -propertyDefaultIfUnset("mappingsVersion", "12") -propertyDefaultIfUnset("usesMavenPublishing", true) -propertyDefaultIfUnset("mavenPublishUrl", "http://jenkins.usrv.eu:8081/nexus/content/repositories/releases") -propertyDefaultIfUnset("modrinthProjectId", "") -propertyDefaultIfUnset("modrinthRelations", "") -propertyDefaultIfUnset("curseForgeProjectId", "") -propertyDefaultIfUnset("curseForgeRelations", "") -propertyDefaultIfUnset("minimizeShadowedDependencies", true) -propertyDefaultIfUnset("relocateShadowedDependencies", true) -// Deprecated properties (kept for backwards compat) -propertyDefaultIfUnset("gradleTokenModId", "") -propertyDefaultIfUnset("gradleTokenModName", "") -propertyDefaultIfUnset("gradleTokenGroupName", "") - -propertyDefaultIfUnset("enableModernJavaSyntax", false) // On by default for new projects only -propertyDefaultIfUnset("enableGenericInjection", false) // On by default for new projects only - -// this is meant to be set using the user wide property file. by default we do nothing. -propertyDefaultIfUnset("ideaOverrideBuildType", "") // Can be nothing, "gradle" or "idea" - -project.extensions.add(com.diffplug.blowdryer.Blowdryer, "Blowdryer", com.diffplug.blowdryer.Blowdryer) // Make blowdryer available in "apply from:" scripts -if (!disableSpotless) { - apply plugin: 'com.diffplug.spotless' - apply from: Blowdryer.file('spotless.gradle') -} - -if (!disableCheckstyle) { - apply plugin: 'checkstyle' - tasks.named("checkstylePatchedMc") { enabled = false } - tasks.named("checkstyleMcLauncher") { enabled = false } - tasks.named("checkstyleIdeVirtualMain") { enabled = false } - tasks.named("checkstyleInjectedTags") { enabled = false } - checkstyle { - config = resources.text.fromString(CHECKSTYLE_CONFIG) - } -} - -String javaSourceDir = "src/main/java/" -String scalaSourceDir = "src/main/scala/" -String kotlinSourceDir = "src/main/kotlin/" - -if (usesShadowedDependencies.toBoolean()) { - apply plugin: "com.github.johnrengelman.shadow" -} - -java { - toolchain { - if (enableModernJavaSyntax.toBoolean()) { - languageVersion.set(JavaLanguageVersion.of(17)) - } else { - languageVersion.set(projectJavaVersion) - } - vendor.set(JvmVendorSpec.AZUL) - } - if (!noPublishedSources) { - withSourcesJar() - } -} - -tasks.withType(JavaCompile).configureEach { - options.encoding = "UTF-8" -} - -tasks.withType(ScalaCompile).configureEach { - options.encoding = "UTF-8" -} - -pluginManager.withPlugin('org.jetbrains.kotlin.jvm') { - // If Kotlin is enabled in the project - kotlin { - jvmToolchain(8) - } - // Kotlin hacks our source sets, so we hack Kotlin's tasks - def disabledKotlinTaskList = [ - "kaptGenerateStubsMcLauncherKotlin", - "kaptGenerateStubsPatchedMcKotlin", - "kaptGenerateStubsInjectedTagsKotlin", - "compileMcLauncherKotlin", - "compilePatchedMcKotlin", - "compileInjectedTagsKotlin", - "kaptMcLauncherKotlin", - "kaptPatchedMcKotlin", - "kaptInjectedTagsKotlin", - "kspMcLauncherKotlin", - "kspPatchedMcKotlin", - "kspInjectedTagsKotlin", - ] - tasks.configureEach { task -> - if (task.name in disabledKotlinTaskList) { - task.enabled = false - } - } -} - -configurations { - create("runtimeOnlyNonPublishable") { - description = "Runtime only dependencies that are not published alongside the jar" - canBeConsumed = false - canBeResolved = false - } - - create("devOnlyNonPublishable") { - description = "Runtime and compiletime dependencies that are not published alongside the jar (compileOnly + runtimeOnlyNonPublishable)" - canBeConsumed = false - canBeResolved = false - } - compileOnly.extendsFrom(devOnlyNonPublishable) - runtimeOnlyNonPublishable.extendsFrom(devOnlyNonPublishable) -} - -if (enableModernJavaSyntax.toBoolean()) { - repositories { - mavenCentral { - mavenContent { - includeGroup("me.eigenraven.java8unsupported") - } - } - } - - dependencies { - annotationProcessor 'com.github.bsideup.jabel:jabel-javac-plugin:1.0.0' - // workaround for https://github.com/bsideup/jabel/issues/174 - annotationProcessor 'net.java.dev.jna:jna-platform:5.13.0' - compileOnly('com.github.bsideup.jabel:jabel-javac-plugin:1.0.0') { - transitive = false // We only care about the 1 annotation class - } - // Allow using jdk.unsupported classes like sun.misc.Unsafe in the compiled code, working around JDK-8206937. - patchedMinecraft('me.eigenraven.java8unsupported:java-8-unsupported-shim:1.0.0') - } - - tasks.withType(JavaCompile).configureEach { - if (it.name in ["compileMcLauncherJava", "compilePatchedMcJava"]) { - return - } - sourceCompatibility = 17 // for the IDE support - options.release.set(8) - - javaCompiler.set(javaToolchains.compilerFor { - languageVersion.set(JavaLanguageVersion.of(17)) - vendor.set(JvmVendorSpec.AZUL) - }) - } -} - -eclipse { - classpath { - downloadSources = true - downloadJavadoc = true - } -} - -final String modGroupPath = modGroup.toString().replace('.' as char, '/' as char) -final String apiPackagePath = apiPackage.toString().replace('.' as char, '/' as char) - -String targetPackageJava = javaSourceDir + modGroupPath -String targetPackageScala = scalaSourceDir + modGroupPath -String targetPackageKotlin = kotlinSourceDir + modGroupPath -if (!(getFile(targetPackageJava).exists() || getFile(targetPackageScala).exists() || getFile(targetPackageKotlin).exists())) { - throw new GradleException("Could not resolve \"modGroup\"! Could not find " + targetPackageJava + " or " + targetPackageScala + " or " + targetPackageKotlin) -} - -if (apiPackage) { - targetPackageJava = javaSourceDir + modGroupPath + "/" + apiPackagePath - targetPackageScala = scalaSourceDir + modGroupPath + "/" + apiPackagePath - targetPackageKotlin = kotlinSourceDir + modGroupPath + "/" + apiPackagePath - if (!(getFile(targetPackageJava).exists() || getFile(targetPackageScala).exists() || getFile(targetPackageKotlin).exists())) { - throw new GradleException("Could not resolve \"apiPackage\"! Could not find " + targetPackageJava + " or " + targetPackageScala + " or " + targetPackageKotlin) - } -} - -if (accessTransformersFile) { - for (atFile in accessTransformersFile.split(" ")) { - String targetFile = "src/main/resources/META-INF/" + atFile.trim() - if (!getFile(targetFile).exists()) { - throw new GradleException("Could not resolve \"accessTransformersFile\"! Could not find " + targetFile) - } - tasks.deobfuscateMergedJarToSrg.accessTransformerFiles.from(targetFile) - tasks.srgifyBinpatchedJar.accessTransformerFiles.from(targetFile) - } -} else { - boolean atsFound = false - for (File at : sourceSets.getByName("main").resources.files) { - if (at.name.toLowerCase().endsWith("_at.cfg")) { - atsFound = true - tasks.deobfuscateMergedJarToSrg.accessTransformerFiles.from(at) - tasks.srgifyBinpatchedJar.accessTransformerFiles.from(at) - } - } - for (File at : sourceSets.getByName("api").resources.files) { - if (at.name.toLowerCase().endsWith("_at.cfg")) { - atsFound = true - tasks.deobfuscateMergedJarToSrg.accessTransformerFiles.from(at) - tasks.srgifyBinpatchedJar.accessTransformerFiles.from(at) - } - } - if (atsFound) { - logger.warn("Found and added access transformers in the resources folder, please configure gradle.properties to explicitly mention them by name") - } -} - -if (usesMixins.toBoolean()) { - if (mixinsPackage.isEmpty()) { - throw new GradleException("\"usesMixins\" requires \"mixinsPackage\" to be set!") - } - final String mixinPackagePath = mixinsPackage.toString().replaceAll("\\.", "/") - final String mixinPluginPath = mixinPlugin.toString().replaceAll("\\.", "/") - - targetPackageJava = javaSourceDir + modGroupPath + "/" + mixinPackagePath - targetPackageScala = scalaSourceDir + modGroupPath + "/" + mixinPackagePath - targetPackageKotlin = kotlinSourceDir + modGroupPath + "/" + mixinPackagePath - if (!(getFile(targetPackageJava).exists() || getFile(targetPackageScala).exists() || getFile(targetPackageKotlin).exists())) { - throw new GradleException("Could not resolve \"mixinsPackage\"! Could not find " + targetPackageJava + " or " + targetPackageScala + " or " + targetPackageKotlin) - } - - if (!mixinPlugin.isEmpty()) { - String targetFileJava = javaSourceDir + modGroupPath + "/" + mixinPluginPath + ".java" - String targetFileScala = scalaSourceDir + modGroupPath + "/" + mixinPluginPath + ".scala" - String targetFileScalaJava = scalaSourceDir + modGroupPath + "/" + mixinPluginPath + ".java" - String targetFileKotlin = kotlinSourceDir + modGroupPath + "/" + mixinPluginPath + ".kt" - if (!(getFile(targetFileJava).exists() || getFile(targetFileScala).exists() || getFile(targetFileScalaJava).exists() || getFile(targetFileKotlin).exists())) { - throw new GradleException("Could not resolve \"mixinPlugin\"! Could not find " + targetFileJava + " or " + targetFileScala + " or " + targetFileScalaJava + " or " + targetFileKotlin) - } - } -} - -if (coreModClass) { - final String coreModPath = coreModClass.toString().replaceAll("\\.", "/") - String targetFileJava = javaSourceDir + modGroupPath + "/" + coreModPath + ".java" - String targetFileScala = scalaSourceDir + modGroupPath + "/" + coreModPath + ".scala" - String targetFileScalaJava = scalaSourceDir + modGroupPath + "/" + coreModPath + ".java" - String targetFileKotlin = kotlinSourceDir + modGroupPath + "/" + coreModPath + ".kt" - if (!(getFile(targetFileJava).exists() || getFile(targetFileScala).exists() || getFile(targetFileScalaJava).exists() || getFile(targetFileKotlin).exists())) { - throw new GradleException("Could not resolve \"coreModClass\"! Could not find " + targetFileJava + " or " + targetFileScala + " or " + targetFileScalaJava + " or " + targetFileKotlin) - } -} - -configurations.configureEach { - resolutionStrategy.cacheChangingModulesFor(0, TimeUnit.SECONDS) - - // Make sure GregTech build won't time out - System.setProperty("org.gradle.internal.http.connectionTimeout", 120000 as String) - System.setProperty("org.gradle.internal.http.socketTimeout", 120000 as String) -} - -// Fix Jenkins' Git: chmod a file should not be detected as a change and append a '.dirty' to the version -try { - 'git config core.fileMode false'.execute() -} -catch (Exception ignored) { - out.style(Style.Failure).println("git isn't installed at all") -} - -// Pulls version first from the VERSION env and then git tag -String identifiedVersion -String versionOverride = System.getenv("VERSION") ?: null -try { - // Produce a version based on the tag, or for branches something like 0.2.2-configurable-maven-and-extras.38+43090270b6-dirty - if (versionOverride == null) { - def gitDetails = versionDetails() - def isDirty = gitVersion().endsWith(".dirty") // No public API for this, isCleanTag has a different meaning - String branchName = gitDetails.branchName ?: (System.getenv('GIT_BRANCH') ?: 'git') - if (branchName.startsWith('origin/')) { - branchName = branchName.minus('origin/') - } - branchName = branchName.replaceAll("[^a-zA-Z0-9-]+", "-") // sanitize branch names for semver - identifiedVersion = gitDetails.lastTag ?: '${gitDetails.gitHash}' - if (gitDetails.commitDistance > 0) { - identifiedVersion += "-${branchName}.${gitDetails.commitDistance}+${gitDetails.gitHash}" - if (isDirty) { - identifiedVersion += "-dirty" - } - } else if (isDirty) { - identifiedVersion += "-${branchName}+${gitDetails.gitHash}-dirty" - } - } else { - identifiedVersion = versionOverride - } -} -catch (Exception ignored) { - out.style(Style.Failure).text( - 'This mod must be version controlled by Git AND the repository must provide at least one tag,\n' + - 'or the VERSION override must be set! ').style(Style.SuccessHeader).text('(Do NOT download from GitHub using the ZIP option, instead\n' + - 'clone the repository, see ').style(Style.Info).text('https://gtnh.miraheze.org/wiki/Development').style(Style.SuccessHeader).println(' for details.)' - ) - versionOverride = 'NO-GIT-TAG-SET' - identifiedVersion = versionOverride -} -version = identifiedVersion -ext { - modVersion = identifiedVersion -} - -if (identifiedVersion == versionOverride) { - out.style(Style.Failure).text('Override version to ').style(Style.Identifier).text(modVersion).style(Style.Failure).println('!\7') -} - -group = "com.github.GTNewHorizons" -if (project.hasProperty("customArchiveBaseName") && customArchiveBaseName) { - base { - archivesName = customArchiveBaseName - } -} else { - base { - archivesName = modId - } -} - - -minecraft { - if (replaceGradleTokenInFile) { - for (f in replaceGradleTokenInFile.split(',')) { - tagReplacementFiles.add f - } - } - if (gradleTokenModId) { - injectedTags.put gradleTokenModId, modId - } - if (gradleTokenModName) { - injectedTags.put gradleTokenModName, modName - } - if (gradleTokenVersion) { - injectedTags.put gradleTokenVersion, modVersion - } - if (gradleTokenGroupName) { - injectedTags.put gradleTokenGroupName, modGroup - } - if (enableGenericInjection.toBoolean()) { - injectMissingGenerics.set(true) - } - - username = developmentEnvironmentUserName.toString() - - lwjgl3Version = "3.3.2" - - // Enable assertions in the current mod - extraRunJvmArguments.add("-ea:${modGroup}") - - if (usesMixins.toBoolean() || forceEnableMixins.toBoolean()) { - if (usesMixinDebug.toBoolean()) { - extraRunJvmArguments.addAll([ - "-Dmixin.debug.countInjections=true", - "-Dmixin.debug.verbose=true", - "-Dmixin.debug.export=true" - ]) - } - } - - // Blowdryer is present in some old mod builds, do not propagate it further as a dependency - // IC2 has no reobf jars in its Maven - groupsToExcludeFromAutoReobfMapping.addAll(["com.diffplug", "com.diffplug.durian", "net.industrial-craft"]) -} - -if (generateGradleTokenClass) { - tasks.injectTags.outputClassName.set(generateGradleTokenClass) -} - -// Custom reobf auto-mappings -configurations.configureEach { - dependencies.configureEach { dep -> - if (dep instanceof org.gradle.api.artifacts.ExternalModuleDependency) { - if (dep.group == "net.industrial-craft" && dep.name == "industrialcraft-2") { - // https://www.curseforge.com/minecraft/mc-mods/industrial-craft/files/2353971 - project.dependencies.reobfJarConfiguration("curse.maven:ic2-242638:2353971") - } - } - } - def obfuscationAttr = it.attributes.getAttribute(ObfuscationAttribute.OBFUSCATION_ATTRIBUTE) - if (obfuscationAttr != null && obfuscationAttr.name == ObfuscationAttribute.SRG) { - resolutionStrategy.eachDependency { DependencyResolveDetails details -> - // Remap CoFH core cursemaven dev jar to the obfuscated version for runObfClient/Server - if (details.requested.group == 'curse.maven' && details.requested.name.endsWith('-69162') && details.requested.version == '2388751') { - details.useVersion '2388750' - details.because 'Pick obfuscated jar' - } - } - } -} - -// Ensure tests have access to minecraft classes -sourceSets { - test { - java { - compileClasspath += sourceSets.patchedMc.output + sourceSets.mcLauncher.output - runtimeClasspath += sourceSets.patchedMc.output + sourceSets.mcLauncher.output - } - } -} - -if (file('addon.gradle.kts').exists()) { - apply from: 'addon.gradle.kts' -} else if (file('addon.gradle').exists()) { - apply from: 'addon.gradle' -} - -// File for local tweaks not commited to Git -if (file('addon.local.gradle.kts').exists()) { - apply from: 'addon.local.gradle.kts' -} else if (file('addon.local.gradle').exists()) { - apply from: 'addon.local.gradle' -} - -// Allow unsafe repos but warn -repositories.configureEach { repo -> - if (repo instanceof org.gradle.api.artifacts.repositories.UrlArtifactRepository) { - if (repo.getUrl() != null && repo.getUrl().getScheme() == "http" && !repo.allowInsecureProtocol) { - logger.warn("Deprecated: Allowing insecure connections for repo '${repo.name}' - add 'allowInsecureProtocol = true'") - repo.allowInsecureProtocol = true - } - } -} - -if (file('repositories.gradle.kts').exists()) { - apply from: 'repositories.gradle.kts' -} else if (file('repositories.gradle').exists()) { - apply from: 'repositories.gradle' -} else { - logger.error("Neither repositories.gradle.kts nor repositories.gradle was found, make sure you extracted the full ExampleMod template.") - throw new RuntimeException("Missing repositories.gradle[.kts]") -} - -configurations { - runtimeClasspath.extendsFrom(runtimeOnlyNonPublishable) - testRuntimeClasspath.extendsFrom(runtimeOnlyNonPublishable) - for (config in [compileClasspath, runtimeClasspath, testCompileClasspath, testRuntimeClasspath]) { - if (usesShadowedDependencies.toBoolean()) { - config.extendsFrom(shadowImplementation) - // TODO: remove Compile after all uses are refactored to Implementation - config.extendsFrom(shadeCompile) - config.extendsFrom(shadowCompile) - } - } - // A "bag-of-dependencies"-style configuration for backwards compatibility, gets put in "api" - create("compile") { - description = "Deprecated: use api or implementation instead, gets put in api" - canBeConsumed = false - canBeResolved = false - visible = false - } - create("testCompile") { - description = "Deprecated: use testImplementation instead" - canBeConsumed = false - canBeResolved = false - visible = false - } - api.extendsFrom(compile) - testImplementation.extendsFrom(testCompile) -} - -afterEvaluate { - if (!configurations.compile.allDependencies.empty || !configurations.testCompile.allDependencies.empty) { - logger.warn("This project uses deprecated `compile` dependencies, please migrate to using `api` and `implementation`") - logger.warn("For more details, see https://github.com/GTNewHorizons/ExampleMod1.7.10/blob/master/dependencies.gradle") - } -} - -repositories { - maven { - name 'Overmind forge repo mirror' - url 'https://gregtech.overminddl1.com/' - } - maven { - name = "GTNH Maven" - url = "http://jenkins.usrv.eu:8081/nexus/content/groups/public/" - allowInsecureProtocol = true - } - maven { - name 'sonatype' - url 'https://oss.sonatype.org/content/repositories/snapshots/' - content { - includeGroup "org.lwjgl" - } - } - if (includeWellKnownRepositories.toBoolean()) { - exclusiveContent { - forRepository { - maven { - name "CurseMaven" - url "https://cursemaven.com" - } - } - filter { - includeGroup "curse.maven" - } - } - exclusiveContent { - forRepository { - maven { - name = "Modrinth" - url = "https://api.modrinth.com/maven" - } - } - filter { - includeGroup "maven.modrinth" - } - } - maven { - name = "ic2" - url = getURL("https://maven2.ic2.player.to/", "https://maven.ic2.player.to/") - content { - includeGroup "net.industrial-craft" - } - metadataSources { - mavenPom() - artifact() - } - } - maven { - name "MMD Maven" - url "https://maven.mcmoddev.com/" - } - } -} - -def mixinProviderGroup = "io.github.legacymoddingmc" -def mixinProviderModule = "unimixins" -def mixinProviderVersion = "0.1.13" -def mixinProviderSpecNoClassifer = "${mixinProviderGroup}:${mixinProviderModule}:${mixinProviderVersion}" -def mixinProviderSpec = "${mixinProviderSpecNoClassifer}:dev" -ext.mixinProviderSpec = mixinProviderSpec - -def mixingConfigRefMap = 'mixins.' + modId + '.refmap.json' - -dependencies { - if (usesMixins.toBoolean()) { - annotationProcessor('org.ow2.asm:asm-debug-all:5.0.3') - annotationProcessor('com.google.guava:guava:24.1.1-jre') - annotationProcessor('com.google.code.gson:gson:2.8.6') - annotationProcessor(mixinProviderSpec) - if (usesMixinDebug.toBoolean()) { - runtimeOnlyNonPublishable('org.jetbrains:intellij-fernflower:1.2.1.16') - } - } - if (usesMixins.toBoolean()) { - implementation(modUtils.enableMixins(mixinProviderSpec, mixingConfigRefMap)) - } else if (forceEnableMixins.toBoolean()) { - runtimeOnlyNonPublishable(mixinProviderSpec) - } -} - -pluginManager.withPlugin('org.jetbrains.kotlin.kapt') { - if (usesMixins.toBoolean()) { - dependencies { - kapt(mixinProviderSpec) - } - } -} - -// Replace old mixin mods with unimixins -// https://docs.gradle.org/8.0.2/userguide/resolution_rules.html#sec:substitution_with_classifier -configurations.all { - resolutionStrategy.dependencySubstitution { - substitute module('com.gtnewhorizon:gtnhmixins') using module(mixinProviderSpecNoClassifer) withClassifier("dev") because("Unimixins replaces other mixin mods") - substitute module('com.github.GTNewHorizons:Mixingasm') using module(mixinProviderSpecNoClassifer) withClassifier("dev") because("Unimixins replaces other mixin mods") - substitute module('com.github.GTNewHorizons:SpongePoweredMixin') using module(mixinProviderSpecNoClassifer) withClassifier("dev") because("Unimixins replaces other mixin mods") - substitute module('com.github.GTNewHorizons:SpongeMixins') using module(mixinProviderSpecNoClassifer) withClassifier("dev") because("Unimixins replaces other mixin mods") - substitute module('io.github.legacymoddingmc:unimixins') using module(mixinProviderSpecNoClassifer) withClassifier("dev") because("Our previous unimixins upload was missing the dev classifier") - - substitute module('org.scala-lang:scala-library:2.11.1') using module('org.scala-lang:scala-library:2.11.5') because('To allow mixing with Java 8 targets') - } -} - -dependencies { - constraints { - def minGtnhLibVersion = "0.0.13" - implementation("com.github.GTNewHorizons:GTNHLib:${minGtnhLibVersion}") { - because("fixes duplicate mod errors in java 17 configurations using old gtnhlib") - } - runtimeOnly("com.github.GTNewHorizons:GTNHLib:${minGtnhLibVersion}") { - because("fixes duplicate mod errors in java 17 configurations using old gtnhlib") - } - devOnlyNonPublishable("com.github.GTNewHorizons:GTNHLib:${minGtnhLibVersion}") { - because("fixes duplicate mod errors in java 17 configurations using old gtnhlib") - } - runtimeOnlyNonPublishable("com.github.GTNewHorizons:GTNHLib:${minGtnhLibVersion}") { - because("fixes duplicate mod errors in java 17 configurations using old gtnhlib") - } - } -} - -if (file('dependencies.gradle.kts').exists()) { - apply from: 'dependencies.gradle.kts' -} else if (file('dependencies.gradle').exists()) { - apply from: 'dependencies.gradle' -} else { - logger.error("Neither dependencies.gradle.kts nor dependencies.gradle was found, make sure you extracted the full ExampleMod template.") - throw new RuntimeException("Missing dependencies.gradle[.kts]") -} - -tasks.register('generateAssets') { - group = "GTNH Buildscript" - description = "Generates a mixin config file at /src/main/resources/mixins.modid.json if needed" - onlyIf { usesMixins.toBoolean() } - doLast { - def mixinConfigFile = getFile("/src/main/resources/mixins." + modId + ".json") - if (!mixinConfigFile.exists()) { - def mixinPluginLine = "" - if (!mixinPlugin.isEmpty()) { - // We might not have a mixin plugin if we're using early/late mixins - mixinPluginLine += """\n "plugin": "${modGroup}.${mixinPlugin}", """ - } - - mixinConfigFile.text = """{ - "required": true, - "minVersion": "0.8.5-GTNH", - "package": "${modGroup}.${mixinsPackage}",${mixinPluginLine} - "refmap": "${mixingConfigRefMap}", - "target": "@env(DEFAULT)", - "compatibilityLevel": "JAVA_8", - "mixins": [], - "client": [], - "server": [] -} -""" - } - } -} - -if (usesMixins.toBoolean()) { - tasks.named("processResources").configure { - dependsOn("generateAssets") - } - - tasks.named("compileJava", JavaCompile).configure { - options.compilerArgs += [ - // Elan: from what I understand they are just some linter configs so you get some warning on how to properly code - "-XDenableSunApiLintControl", - "-XDignore.symbol.file" - ] - } -} - -tasks.named("processResources", ProcessResources).configure { - // this will ensure that this task is redone when the versions change. - inputs.property "version", project.version - inputs.property "mcversion", project.minecraft.mcVersion - exclude("spotless.gradle") - - // replace stuff in mcmod.info, nothing else. replaces ${key} with value in text - filesMatching("mcmod.info") { - expand "minecraftVersion": project.minecraft.mcVersion, - "modVersion": modVersion, - "modId": modId, - "modName": modName - } - - if (usesMixins.toBoolean()) { - dependsOn("compileJava", "compileScala") - } -} - -ext.java17Toolchain = (JavaToolchainSpec spec) -> { - spec.languageVersion.set(JavaLanguageVersion.of(17)) - spec.vendor.set(JvmVendorSpec.matching("jetbrains")) -} - -ext.java17DependenciesCfg = configurations.create("java17Dependencies") { - extendsFrom(configurations.getByName("runtimeClasspath")) // Ensure consistent transitive dependency resolution - canBeConsumed = false -} -ext.java17PatchDependenciesCfg = configurations.create("java17PatchDependencies") { - canBeConsumed = false -} - -dependencies { - def lwjgl3ifyVersion = '1.5.7' - if (modId != 'lwjgl3ify') { - java17Dependencies("com.github.GTNewHorizons:lwjgl3ify:${lwjgl3ifyVersion}") - } - if (modId != 'hodgepodge') { - java17Dependencies('com.github.GTNewHorizons:Hodgepodge:2.3.35') - } - - java17PatchDependencies("com.github.GTNewHorizons:lwjgl3ify:${lwjgl3ifyVersion}:forgePatches") {transitive = false} -} - -ext.java17JvmArgs = [ - // Java 9+ support - "--illegal-access=warn", - "-Djava.security.manager=allow", - "-Dfile.encoding=UTF-8", - "--add-opens", "java.base/jdk.internal.loader=ALL-UNNAMED", - "--add-opens", "java.base/java.net=ALL-UNNAMED", - "--add-opens", "java.base/java.nio=ALL-UNNAMED", - "--add-opens", "java.base/java.io=ALL-UNNAMED", - "--add-opens", "java.base/java.lang=ALL-UNNAMED", - "--add-opens", "java.base/java.lang.reflect=ALL-UNNAMED", - "--add-opens", "java.base/java.text=ALL-UNNAMED", - "--add-opens", "java.base/java.util=ALL-UNNAMED", - "--add-opens", "java.base/jdk.internal.reflect=ALL-UNNAMED", - "--add-opens", "java.base/sun.nio.ch=ALL-UNNAMED", - "--add-opens", "jdk.naming.dns/com.sun.jndi.dns=ALL-UNNAMED,java.naming", - "--add-opens", "java.desktop/sun.awt.image=ALL-UNNAMED", - "--add-modules", "jdk.dynalink", - "--add-opens", "jdk.dynalink/jdk.dynalink.beans=ALL-UNNAMED", - "--add-modules", "java.sql.rowset", - "--add-opens", "java.sql.rowset/javax.sql.rowset.serial=ALL-UNNAMED" -] - -ext.hotswapJvmArgs = [ - // DCEVM advanced hot reload - "-XX:+AllowEnhancedClassRedefinition", - "-XX:HotswapAgent=fatjar" -] - -ext.setupHotswapAgentTask = tasks.register("setupHotswapAgent") { - group = "GTNH Buildscript" - description = "Installs a recent version of HotSwapAgent into the Java 17 JetBrains runtime directory" - def hsaUrl = 'https://github.com/HotswapProjects/HotswapAgent/releases/download/1.4.2-SNAPSHOT/hotswap-agent-1.4.2-SNAPSHOT.jar' - def targetFolderProvider = javaToolchains.launcherFor(java17Toolchain).map {it.metadata.installationPath.dir("lib/hotswap")} - def targetFilename = "hotswap-agent.jar" - onlyIf { - !targetFolderProvider.get().file(targetFilename).asFile.exists() - } - doLast { - def targetFolder = targetFolderProvider.get() - targetFolder.asFile.mkdirs() - download.run { - src hsaUrl - dest targetFolder.file(targetFilename).asFile - overwrite false - tempAndMove true - } - } -} - -public abstract class RunHotswappableMinecraftTask extends RunMinecraftTask { - // IntelliJ doesn't seem to allow commandline arguments so we also support an env variable - private boolean enableHotswap = Boolean.valueOf(System.getenv("HOTSWAP")); - - @Input - public boolean getEnableHotswap() { return enableHotswap } - @Option(option = "hotswap", description = "Enables HotSwapAgent for enhanced class reloading under a debugger") - public boolean setEnableHotswap(boolean enable) { enableHotswap = enable } - - @Inject - public RunHotswappableMinecraftTask(Distribution side, String superTask, org.gradle.api.invocation.Gradle gradle) { - super(side, gradle) - - this.lwjglVersion = 3 - this.javaLauncher = project.javaToolchains.launcherFor(project.java17Toolchain) - this.extraJvmArgs.addAll(project.java17JvmArgs) - this.extraJvmArgs.addAll(project.provider(() -> enableHotswap ? project.hotswapJvmArgs : [])) - - this.classpath(project.java17PatchDependenciesCfg) - if (side == Distribution.CLIENT) { - this.classpath(project.minecraftTasks.lwjgl3Configuration) - } - // Use a raw provider instead of map to not create a dependency on the task - this.classpath(project.provider(() -> project.tasks.named(superTask, RunMinecraftTask).get().classpath)) - this.classpath.filter { file -> - !file.path.contains("2.9.4-nightly-20150209") // Remove lwjgl2 - } - this.classpath(project.java17DependenciesCfg) - } - - public void setup(Project project) { - super.setup(project) - if (project.usesMixins.toBoolean()) { - this.extraJvmArgs.addAll(project.provider(() -> { - def mixinCfg = project.configurations.detachedConfiguration(project.dependencies.create(project.mixinProviderSpec)) - mixinCfg.canBeConsumed = false - mixinCfg.transitive = false - enableHotswap ? ["-javaagent:" + mixinCfg.singleFile.absolutePath] : [] - })) - } - } -} - -def runClient17Task = tasks.register("runClient17", RunHotswappableMinecraftTask, Distribution.CLIENT, "runClient") -runClient17Task.configure { - setup(project) - group = "Modded Minecraft" - description = "Runs the modded client using Java 17, lwjgl3ify and Hodgepodge" - dependsOn(setupHotswapAgentTask, mcpTasks.launcherSources.classesTaskName, minecraftTasks.taskDownloadVanillaAssets, mcpTasks.taskPackagePatchedMc, 'jar') - mainClass = "GradleStart" - username = minecraft.username - userUUID = minecraft.userUUID -} - -def runServer17Task = tasks.register("runServer17", RunHotswappableMinecraftTask, Distribution.DEDICATED_SERVER, "runServer") -runServer17Task.configure { - setup(project) - group = "Modded Minecraft" - description = "Runs the modded server using Java 17, lwjgl3ify and Hodgepodge" - dependsOn(setupHotswapAgentTask, mcpTasks.launcherSources.classesTaskName, minecraftTasks.taskDownloadVanillaAssets, mcpTasks.taskPackagePatchedMc, 'jar') - mainClass = "GradleStartServer" - extraArgs.add("nogui") -} - -def getManifestAttributes() { - def manifestAttributes = [:] - if (!containsMixinsAndOrCoreModOnly.toBoolean() && (usesMixins.toBoolean() || coreModClass)) { - manifestAttributes += ["FMLCorePluginContainsFMLMod": true] - } - - if (accessTransformersFile) { - manifestAttributes += ["FMLAT": accessTransformersFile.toString()] - } - - if (coreModClass) { - manifestAttributes += ["FMLCorePlugin": modGroup + "." + coreModClass] - } - - if (usesMixins.toBoolean()) { - manifestAttributes += [ - "TweakClass" : "org.spongepowered.asm.launch.MixinTweaker", - "MixinConfigs" : "mixins." + modId + ".json", - "ForceLoadAsMod": !containsMixinsAndOrCoreModOnly.toBoolean() - ] - } - return manifestAttributes -} - -tasks.named("jar", Jar).configure { - manifest { - attributes(getManifestAttributes()) - } -} - -if (usesShadowedDependencies.toBoolean()) { - tasks.named("shadowJar", ShadowJar).configure { - manifest { - attributes(getManifestAttributes()) - } - - if (minimizeShadowedDependencies.toBoolean()) { - minimize() // This will only allow shading for actually used classes - } - configurations = [ - project.configurations.shadowImplementation, - project.configurations.shadowCompile, - project.configurations.shadeCompile - ] - archiveClassifier.set('dev') - if (relocateShadowedDependencies.toBoolean()) { - relocationPrefix = modGroup + ".shadow" - enableRelocation = true - } - } - configurations.runtimeElements.outgoing.artifacts.clear() - configurations.apiElements.outgoing.artifacts.clear() - configurations.runtimeElements.outgoing.artifact(tasks.named("shadowJar", ShadowJar)) - configurations.apiElements.outgoing.artifact(tasks.named("shadowJar", ShadowJar)) - tasks.named("jar", Jar) { - enabled = false - finalizedBy(tasks.shadowJar) - } - tasks.named("reobfJar", ReobfuscatedJar) { - inputJar.set(tasks.named("shadowJar", ShadowJar).flatMap({it.archiveFile})) - } - AdhocComponentWithVariants javaComponent = (AdhocComponentWithVariants) project.components.findByName("java") - javaComponent.withVariantsFromConfiguration(configurations.shadowRuntimeElements) { - skip() - } - for (runTask in ["runClient", "runServer", "runClient17", "runServer17"]) { - tasks.named(runTask).configure { - dependsOn("shadowJar") - } - } -} -ext.publishableDevJar = usesShadowedDependencies.toBoolean() ? tasks.shadowJar : tasks.jar -ext.publishableObfJar = tasks.reobfJar - -tasks.register('apiJar', Jar) { - from(sourceSets.main.allSource) { - include modGroupPath + "/" + apiPackagePath + '/**' - } - - from(sourceSets.main.output) { - include modGroupPath + "/" + apiPackagePath + '/**' - } - - from(sourceSets.main.resources.srcDirs) { - include("LICENSE") - } - - getArchiveClassifier().set('api') -} - -artifacts { - if (!noPublishedSources) { - archives tasks.named("sourcesJar") - } - if (apiPackage) { - archives tasks.named("apiJar") - } -} - -idea { - module { - downloadJavadoc = true - downloadSources = true - inheritOutputDirs = true - } - project { - settings { - if (ideaOverrideBuildType != "") { - delegateActions { - if ("gradle".equalsIgnoreCase(ideaOverrideBuildType)) { - delegateBuildRunToGradle = true - testRunner = org.jetbrains.gradle.ext.ActionDelegationConfig.TestRunner.GRADLE - } else if ("idea".equalsIgnoreCase(ideaOverrideBuildType)) { - delegateBuildRunToGradle = false - testRunner = org.jetbrains.gradle.ext.ActionDelegationConfig.TestRunner.PLATFORM - } else { - throw GradleScriptException('Accepted value for ideaOverrideBuildType is one of gradle or idea.') - } - } - } - runConfigurations { - "0. Build and Test"(Gradle) { - taskNames = ["build"] - } - "1. Run Client"(Gradle) { - taskNames = ["runClient"] - } - "2. Run Server"(Gradle) { - taskNames = ["runServer"] - } - "1a. Run Client (Java 17)"(Gradle) { - taskNames = ["runClient17"] - } - "2a. Run Server (Java 17)"(Gradle) { - taskNames = ["runServer17"] - } - "1b. Run Client (Java 17, Hotswap)"(Gradle) { - taskNames = ["runClient17"] - envs = ["HOTSWAP": "true"] - } - "2b. Run Server (Java 17, Hotswap)"(Gradle) { - taskNames = ["runServer17"] - envs = ["HOTSWAP": "true"] - } - "3. Run Obfuscated Client"(Gradle) { - taskNames = ["runObfClient"] - } - "4. Run Obfuscated Server"(Gradle) { - taskNames = ["runObfServer"] - } - if (!disableSpotless) { - "5. Apply spotless"(Gradle) { - taskNames = ["spotlessApply"] - } - } - def coreModArgs = "" - if (coreModClass) { - coreModArgs = ' "-Dfml.coreMods.load=' + modGroup + '.' + coreModClass + '"' - } - "Run Client (IJ Native)"(Application) { - mainClass = "GradleStart" - moduleName = project.name + ".ideVirtualMain" - afterEvaluate { - workingDirectory = tasks.runClient.workingDir.absolutePath - programParameters = tasks.runClient.calculateArgs(project).collect { '"' + it + '"' }.join(' ') - jvmArgs = tasks.runClient.calculateJvmArgs(project).collect { '"' + it + '"' }.join(' ') + - ' ' + tasks.runClient.systemProperties.collect { '"-D' + it.key + '=' + it.value.toString() + '"' }.join(' ') + - coreModArgs - } - } - "Run Server (IJ Native)"(Application) { - mainClass = "GradleStartServer" - moduleName = project.name + ".ideVirtualMain" - afterEvaluate { - workingDirectory = tasks.runServer.workingDir.absolutePath - programParameters = tasks.runServer.calculateArgs(project).collect { '"' + it + '"' }.join(' ') - jvmArgs = tasks.runServer.calculateJvmArgs(project).collect { '"' + it + '"' }.join(' ') + - ' ' + tasks.runServer.systemProperties.collect { '"-D' + it.key + '=' + it.value.toString() + '"' }.join(' ') + - coreModArgs - } - } - } - compiler.javac { - afterEvaluate { - javacAdditionalOptions = "-encoding utf8" - moduleJavacAdditionalOptions = [ - (project.name + ".main"): tasks.compileJava.options.compilerArgs.collect { '"' + it + '"' }.join(' ') - ] - } - } - withIDEADir { File ideaDir -> - if (!ideaDir.path.contains(".idea")) { - // If an .ipr file exists, the project root directory is passed here instead of the .idea subdirectory - ideaDir = new File(ideaDir, ".idea") - } - if (ideaDir.isDirectory()) { - def miscFile = new File(ideaDir, "misc.xml") - if (miscFile.isFile()) { - boolean dirty = false - def miscTransformer = new XmlTransformer() - miscTransformer.addAction { root -> - Node rootNode = root.asNode() - def rootManager = rootNode - .component.find { it.@name == 'ProjectRootManager' } - if (!rootManager) { - rootManager = rootNode.appendNode('component', ['name': 'ProjectRootManager', 'version': '2']) - dirty = true - } - def output = rootManager.output - if (!output) { - output = rootManager.appendNode('output') - dirty = true - } - if (!output.@url) { - // Only modify the output url if it doesn't yet have one, or if the existing one is blank somehow. - // This is a sensible default for most setups - output.@url = 'file://$PROJECT_DIR$/build/ideaBuild' - dirty = true - } - } - def result = miscTransformer.transform(miscFile.text) - if (dirty) { - miscFile.write(result) - } - } else { - miscFile.text = """ - - - - - -""" - } - } - } - } - } -} - -tasks.named("processIdeaSettings").configure { - dependsOn("injectTags") -} - -tasks.named("ideVirtualMainClasses").configure { - // Make IntelliJ "Build project" build the mod jars - dependsOn("jar", "reobfJar") - if (!disableSpotless) { - dependsOn("spotlessCheck") - } -} - -// workaround variable hiding in pom processing -def projectConfigs = project.configurations - -publishing { - publications { - create("maven", MavenPublication) { - from components.java - - if (apiPackage) { - artifact apiJar - } - - groupId = System.getenv("ARTIFACT_GROUP_ID") ?: project.group - artifactId = System.getenv("ARTIFACT_ID") ?: project.name - // Using the identified version, not project.version as it has the prepended 1.7.10 - version = System.getenv("RELEASE_VERSION") ?: identifiedVersion - } - } - repositories { - if (usesMavenPublishing.toBoolean() && System.getenv("MAVEN_USER") != null) { - maven { - url = mavenPublishUrl - allowInsecureProtocol = mavenPublishUrl.startsWith("http://") // Mostly for the GTNH maven - credentials { - username = System.getenv("MAVEN_USER") ?: "NONE" - password = System.getenv("MAVEN_PASSWORD") ?: "NONE" - } - } - } - } -} - -if (modrinthProjectId.size() != 0 && System.getenv("MODRINTH_TOKEN") != null) { - apply plugin: 'com.modrinth.minotaur' - - File changelogFile = new File(System.getenv("CHANGELOG_FILE") ?: "CHANGELOG.md") - - modrinth { - token = System.getenv("MODRINTH_TOKEN") - projectId = modrinthProjectId - versionNumber = identifiedVersion - versionType = identifiedVersion.endsWith("-pre") ? "beta" : "release" - changelog = changelogFile.exists() ? changelogFile.getText("UTF-8") : "" - uploadFile = publishableObfJar - additionalFiles = getSecondaryArtifacts() - gameVersions = [minecraftVersion] - loaders = ["forge"] - debugMode = false - } - - if (modrinthRelations.size() != 0) { - String[] deps = modrinthRelations.split(";") - deps.each { dep -> - if (dep.size() == 0) { - return - } - String[] parts = dep.split(":") - String[] qual = parts[0].split("-") - addModrinthDep(qual[0], qual[1], parts[1]) - } - } - if (usesMixins.toBoolean()) { - addModrinthDep("required", "project", "unimixins") - } - tasks.modrinth.dependsOn(build) - tasks.publish.dependsOn(tasks.modrinth) -} - -if (curseForgeProjectId.size() != 0 && System.getenv("CURSEFORGE_TOKEN") != null) { - apply plugin: 'com.matthewprenger.cursegradle' - - File changelogFile = new File(System.getenv("CHANGELOG_FILE") ?: "CHANGELOG.md") - - curseforge { - apiKey = System.getenv("CURSEFORGE_TOKEN") - project { - id = curseForgeProjectId - if (changelogFile.exists()) { - changelogType = "markdown" - changelog = changelogFile - } - releaseType = identifiedVersion.endsWith("-pre") ? "beta" : "release" - addGameVersion minecraftVersion - addGameVersion "Forge" - mainArtifact publishableObfJar - for (artifact in getSecondaryArtifacts()) addArtifact artifact - } - - options { - javaIntegration = false - forgeGradleIntegration = false - debug = false - } - } - - if (curseForgeRelations.size() != 0) { - String[] deps = curseForgeRelations.split(";") - deps.each { dep -> - if (dep.size() == 0) { - return - } - String[] parts = dep.split(":") - addCurseForgeRelation(parts[0], parts[1]) - } - } - if (usesMixins.toBoolean()) { - addCurseForgeRelation("requiredDependency", "unimixins") - } - tasks.curseforge.dependsOn(build) - tasks.publish.dependsOn(tasks.curseforge) -} - -def addModrinthDep(String scope, String type, String name) { - com.modrinth.minotaur.dependencies.Dependency dep; - if (!(scope in ["required", "optional", "incompatible", "embedded"])) { - throw new Exception("Invalid modrinth dependency scope: " + scope) - } - switch (type) { - case "project": - dep = new ModDependency(name, scope) - break - case "version": - dep = new VersionDependency(name, scope) - break - default: - throw new Exception("Invalid modrinth dependency type: " + type) - } - project.modrinth.dependencies.add(dep) -} - -def addCurseForgeRelation(String type, String name) { - if (!(type in ["requiredDependency", "embeddedLibrary", "optionalDependency", "tool", "incompatible"])) { - throw new Exception("Invalid CurseForge relation type: " + type) - } - CurseArtifact artifact = project.curseforge.curseProjects[0].mainArtifact - CurseRelation rel = (artifact.curseRelations ?: (artifact.curseRelations = new CurseRelation())) - rel."$type"(name) -} - -// Updating - -def buildscriptGradleVersion = "8.5" - -tasks.named('wrapper', Wrapper).configure { - gradleVersion = buildscriptGradleVersion -} - -tasks.register('updateBuildScript') { - group = 'GTNH Buildscript' - description = 'Updates the build script to the latest version' - - if (gradle.gradleVersion != buildscriptGradleVersion && !Boolean.getBoolean('DISABLE_BUILDSCRIPT_GRADLE_UPDATE')) { - dependsOn('wrapper') - } - - doLast { - if (performBuildScriptUpdate()) return - - print("Build script already up-to-date!") - } -} - -if (!project.getGradle().startParameter.isOffline() && !Boolean.getBoolean('DISABLE_BUILDSCRIPT_UPDATE_CHECK') && isNewBuildScriptVersionAvailable()) { - if (autoUpdateBuildScript.toBoolean()) { - performBuildScriptUpdate() - } else { - out.style(Style.SuccessHeader).println("Build script update available! Run 'gradle updateBuildScript'") - if (gradle.gradleVersion != buildscriptGradleVersion) { - out.style(Style.SuccessHeader).println("updateBuildScript can update gradle from ${gradle.gradleVersion} to ${buildscriptGradleVersion}\n") - } - } -} - -// If you want to add more cases to this task, implement them as arguments if total amount to print gets too large -tasks.register('faq') { - group = 'GTNH Buildscript' - description = 'Prints frequently asked questions about building a project' - - doLast { - print("If your build fails to fetch dependencies, run './gradlew updateDependencies'. " + - "Or you can manually check if the versions are still on the distributing sites - " + - "the links can be found in repositories.gradle and build.gradle:repositories, " + - "but not build.gradle:buildscript.repositories - those ones are for gradle plugin metadata.\n\n" + - "If your build fails to recognize the syntax of new Java versions, enable Jabel in your " + - "gradle.properties. See how it's done in GTNH ExampleMod/gradle.properties. " + - "However, keep in mind that Jabel enables only syntax features, but not APIs that were introduced in " + - "Java 9 or later.") - } -} - -static URL availableBuildScriptUrl() { - new URL("https://raw.githubusercontent.com/GTNewHorizons/ExampleMod1.7.10/master/build.gradle") -} - -static URL exampleSettingsGradleUrl() { - new URL("https://raw.githubusercontent.com/GTNewHorizons/ExampleMod1.7.10/master/settings.gradle.example") -} - -static URL exampleGitAttributesUrl() { - new URL("https://raw.githubusercontent.com/GTNewHorizons/ExampleMod1.7.10/master/.gitattributes") -} - - -boolean verifyGitAttributes() { - def gitattributesFile = getFile(".gitattributes") - if (!gitattributesFile.exists()) { - println("Downloading default .gitattributes") - exampleGitAttributesUrl().withInputStream { i -> gitattributesFile.withOutputStream { it << i } } - exec { - workingDir '.' - commandLine 'git', 'add', '--renormalize', '.' - } - return true - } - return false -} - -boolean verifySettingsGradle() { - def settingsFile = getFile("settings.gradle") - if (!settingsFile.exists()) { - println("Downloading default settings.gradle") - exampleSettingsGradleUrl().withInputStream { i -> settingsFile.withOutputStream { it << i } } - return true - } - return false -} - -boolean performBuildScriptUpdate() { - if (isNewBuildScriptVersionAvailable()) { - def buildscriptFile = getFile("build.gradle") - availableBuildScriptUrl().withInputStream { i -> buildscriptFile.withOutputStream { it << i } } - def out = services.get(StyledTextOutputFactory).create('buildscript-update-output') - out.style(Style.Success).print("Build script updated. Please REIMPORT the project or RESTART your IDE!") - boolean settingsupdated = verifySettingsGradle() - settingsupdated = verifyGitAttributes() || settingsupdated - if (settingsupdated) - throw new GradleException("Settings has been updated, please re-run task.") - return true - } - return false -} - -boolean isNewBuildScriptVersionAvailable() { - Map parameters = ["connectTimeout": 2000, "readTimeout": 2000] - - String currentBuildScript = getFile("build.gradle").getText() - String currentBuildScriptHash = getVersionHash(currentBuildScript) - String availableBuildScriptHash - try { - String availableBuildScript = availableBuildScriptUrl().newInputStream(parameters).getText() - availableBuildScriptHash = getVersionHash(availableBuildScript) - } catch (IOException e) { - logger.warn("Could not check for buildscript update availability: {}", e.message) - return false - } - - boolean isUpToDate = currentBuildScriptHash.empty || availableBuildScriptHash.empty || currentBuildScriptHash == availableBuildScriptHash - return !isUpToDate -} - -static String getVersionHash(String buildScriptContent) { - String versionLine = buildScriptContent.find("^//version: [a-z0-9]*") - if (versionLine != null) { - return versionLine.split(": ").last() - } - return "" -} - -// Parameter Deobfuscation - -tasks.register('deobfParams') { - group = 'GTNH Buildscript' - description = 'Rename all obfuscated parameter names inherited from Minecraft classes' - doLast { // TODO - - String mcpDir = "$project.gradle.gradleUserHomeDir/caches/minecraft/de/oceanlabs/mcp/mcp_$channel/$mappingsVersion" - String mcpZIP = "$mcpDir/mcp_$channel-$mappingsVersion-${minecraftVersion}.zip" - String paramsCSV = "$mcpDir/params.csv" - - download.run { - src "https://maven.minecraftforge.net/de/oceanlabs/mcp/mcp_$channel/$mappingsVersion-$minecraftVersion/mcp_$channel-$mappingsVersion-${minecraftVersion}.zip" - dest mcpZIP - overwrite false - } - - if (!file(paramsCSV).exists()) { - println("Extracting MCP archive ...") - copy { - from(zipTree(mcpZIP)) - into(mcpDir) - } - } - - println("Parsing params.csv ...") - Map params = new HashMap<>() - Files.lines(Paths.get(paramsCSV)).forEach { line -> - String[] cells = line.split(",") - if (cells.length > 2 && cells[0].matches("p_i?\\d+_\\d+_")) { - params.put(cells[0], cells[1]) - } - } - - out.style(Style.Success).println("Modified ${replaceParams(file("$projectDir/src/main/java"), params)} files!") - out.style(Style.Failure).println("Don't forget to verify that the code still works as before!\n It could be broken due to duplicate variables existing now\n or parameters taking priority over other variables.") - } -} - -static int replaceParams(File file, Map params) { - int fileCount = 0 - - if (file.isDirectory()) { - for (File f : file.listFiles()) { - fileCount += replaceParams(f, params) - } - return fileCount - } - println("Visiting ${file.getName()} ...") - try { - String content = new String(Files.readAllBytes(file.toPath())) - int hash = content.hashCode() - params.forEach { key, value -> - content = content.replaceAll(key, value) - } - if (hash != content.hashCode()) { - Files.write(file.toPath(), content.getBytes("UTF-8")) - return 1 - } - } catch (Exception e) { - e.printStackTrace() - } - return 0 -} - -// Dependency Deobfuscation (Deprecated, use the new RFG API documented in dependencies.gradle) - -def deobf(String sourceURL) { - try { - URL url = new URL(sourceURL) - String fileName = url.getFile() - - //get rid of directories: - int lastSlash = fileName.lastIndexOf("/") - if (lastSlash > 0) { - fileName = fileName.substring(lastSlash + 1) - } - //get rid of extension: - if (fileName.endsWith(".jar") || fileName.endsWith(".litemod")) { - fileName = fileName.substring(0, fileName.lastIndexOf(".")) - } - - String hostName = url.getHost() - if (hostName.startsWith("www.")) { - hostName = hostName.substring(4) - } - List parts = Arrays.asList(hostName.split("\\.")) - Collections.reverse(parts) - hostName = String.join(".", parts) - - return deobf(sourceURL, "$hostName/$fileName") - } catch (Exception ignored) { - return deobf(sourceURL, "deobf/${sourceURL.hashCode()}") - } -} - -def deobfMaven(String repoURL, String mavenDep) { - if (!repoURL.endsWith("/")) { - repoURL += "/" - } - String[] parts = mavenDep.split(":") - parts[0] = parts[0].replace('.', '/') - def jarURL = repoURL + parts[0] + "/" + parts[1] + "/" + parts[2] + "/" + parts[1] + "-" + parts[2] + ".jar" - return deobf(jarURL) -} - -def deobfCurse(String curseDep) { - return dependencies.rfg.deobf("curse.maven:$curseDep") -} - -// The method above is to be preferred. Use this method if the filename is not at the end of the URL. -def deobf(String sourceURL, String rawFileName) { - String bon2Version = "2.5.1" - String fileName = URLDecoder.decode(rawFileName, "UTF-8") - String cacheDir = "$project.gradle.gradleUserHomeDir/caches" - String obfFile = "$cacheDir/modules-2/files-2.1/${fileName}.jar" - - download.run { - src sourceURL - dest obfFile - quiet true - overwrite false - } - return dependencies.rfg.deobf(files(obfFile)) -} -// Helper methods - -def checkPropertyExists(String propertyName) { - if (!project.hasProperty(propertyName)) { - throw new GradleException("This project requires a property \"" + propertyName + "\"! Please add it your \"gradle.properties\". You can find all properties and their description here: https://github.com/GTNewHorizons/ExampleMod1.7.10/blob/main/gradle.properties") - } -} - -def propertyDefaultIfUnset(String propertyName, defaultValue) { - if (!project.hasProperty(propertyName) || project.property(propertyName) == "") { - project.ext.setProperty(propertyName, defaultValue) - } -} - -def getFile(String relativePath) { - return new File(projectDir, relativePath) -} - -def getSecondaryArtifacts() { - // Because noPublishedSources from the beginning of the script is somehow not visible here... - boolean noPublishedSources = project.hasProperty("noPublishedSources") ? project.noPublishedSources.toBoolean() : false - def secondaryArtifacts = [publishableDevJar] - if (!noPublishedSources) secondaryArtifacts += [sourcesJar] - if (apiPackage) secondaryArtifacts += [apiJar] - return secondaryArtifacts -} - -def getURL(String main, String fallback) { - return pingURL(main, 10000) ? main : fallback -} - -// credit: https://stackoverflow.com/a/3584332 -def pingURL(String url, int timeout) { - url = url.replaceFirst("^https", "http") // Otherwise an exception may be thrown on invalid SSL certificates. - try { - HttpURLConnection connection = (HttpURLConnection) new URL(url).openConnection() - connection.setConnectTimeout(timeout) - connection.setReadTimeout(timeout) - connection.setRequestMethod("HEAD") - int responseCode = connection.getResponseCode() - return 200 <= responseCode && responseCode <= 399 - } catch (IOException ignored) { - return false - } -} - -// For easier scripting of things that require variables defined earlier in the buildscript -if (file('addon.late.gradle.kts').exists()) { - apply from: 'addon.late.gradle.kts' -} else if (file('addon.late.gradle').exists()) { - apply from: 'addon.late.gradle' -} - -// File for local tweaks not commited to Git -if (file('addon.late.local.gradle.kts').exists()) { - apply from: 'addon.late.local.gradle.kts' -} else if (file('addon.late.local.gradle').exists()) { - apply from: 'addon.late.local.gradle' + id 'com.gtnewhorizons.gtnhconvention' } diff --git a/gradle.properties b/gradle.properties index 4228e19..c7481a2 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,77 +1,104 @@ +# ExampleMod tag to use as Blowdryer (Spotless, etc.) settings version, leave empty to disable. +# LOCAL to test local config updates. +gtnh.settings.blowdryerTag = 0.2.2 + +# Human-readable mod name, available for mcmod.info population. modName = ChickenChunks -# This is a case-sensitive string to identify your mod. Convention is to use lower case. +# Case-sensitive identifier string, available for mcmod.info population and used for automatic mixin JSON generation. +# Conventionally lowercase. modId = ChickenChunks +# Root package of the mod, used to find various classes in other properties, +# mcmod.info substitution, enabling assertions in run tasks, etc. modGroup = codechicken.chunkloader -# WHY is there no version field? -# The build script relies on git to provide a version via tags. It is super easy and will enable you to always know the -# code base or your binary. Check out this tutorial: https://blog.mattclemente.com/2017/10/13/versioning-with-git-tags/ +# Whether to use modGroup as the maven publishing group. +# Due to a history of using JitPack, the default is com.github.GTNewHorizons for all mods. +useModGroupForPublishing = false -# Will update your build.gradle automatically whenever an update is available +# Updates your build.gradle and settings.gradle automatically whenever an update is available. autoUpdateBuildScript = false +# Version of Minecraft to target minecraftVersion = 1.7.10 + +# Version of Minecraft Forge to target forgeVersion = 10.13.4.1614 -# Specify a MCP channel and mappings version for dependency deobfuscation and the deobfParams task. +# Specify an MCP channel for dependency deobfuscation and the deobfParams task. channel = stable + +# Specify an MCP mappings version for dependency deobfuscation and the deobfParams task. mappingsVersion = 12 -# Define other MCP mappings for dependency deobfuscation -remoteMappings = https://raw.githubusercontent.com/MinecraftForge/FML/1.7.10/conf/ +# Defines other MCP mappings for dependency deobfuscation. +remoteMappings = https\://raw.githubusercontent.com/MinecraftForge/FML/1.7.10/conf/ -# Select a username for testing your mod with breakpoints. You may leave this empty for a random username each time you -# restart Minecraft in development. Choose this dependent on your mod: -# Do you need consistent player progressing (for example Thaumcraft)? -> Select a name -# Do you need to test how your custom blocks interacts with a player that is not the owner? -> leave name empty +# Select a default username for testing your mod. You can always override this per-run by running +# `./gradlew runClient --username=AnotherPlayer`, or configuring this command in your IDE. developmentEnvironmentUserName = Developer -# Enables using modern java syntax (up to version 17) via Jabel, while still targetting JVM 8. +# Enables using modern Java syntax (up to version 17) via Jabel, while still targeting JVM 8. # See https://github.com/bsideup/jabel for details on how this works. enableModernJavaSyntax = true -# Enables injecting missing generics into the decompiled source code for a better coding experience -# Turns most publically visible List, Map, etc. into proper List, Map types +# Enables injecting missing generics into the decompiled source code for a better coding experience. +# Turns most publicly visible List, Map, etc. into proper List, Map types. enableGenericInjection = false -# Generate a class with String fields for the mod id, name, version and group name named with the fields below +# Generate a class with a String field for the mod version named as defined below. +# If generateGradleTokenClass is empty or not missing, no such class will be generated. +# If gradleTokenVersion is empty or missing, the field will not be present in the class. generateGradleTokenClass = codechicken.chunkloader.Tags + +# Name of the token containing the project's current version to generate/replace. +gradleTokenVersion = VERSION + +# [DEPRECATED] Mod ID replacement token. gradleTokenModId = MODID + +# [DEPRECATED] Mod name replacement token. gradleTokenModName = MODNAME -gradleTokenVersion = VERSION + +# [DEPRECATED] Mod Group replacement token. gradleTokenGroupName = GROUPNAME + # [DEPRECATED] -# Multiple source files can be defined here by providing a comma-seperated list: Class1.java,Class2.java,Class3.java +# Multiple source files can be defined here by providing a comma-separated list: Class1.java,Class2.java,Class3.java # public static final String VERSION = "GRADLETOKEN_VERSION"; # The string's content will be replaced with your mod's version when compiled. You should use this to specify your mod's -# version in @Mod([...], version = VERSION, [...]) -# Leave these properties empty to skip individual token replacements +# version in @Mod([...], version = VERSION, [...]). +# Leave these properties empty to skip individual token replacements. replaceGradleTokenInFile = # In case your mod provides an API for other mods to implement you may declare its package here. Otherwise, you can # leave this property empty. -# Example value: apiPackage = api + modGroup = com.myname.mymodid -> com.myname.mymodid.api +# Example value: (apiPackage = api) + (modGroup = com.myname.mymodid) -> com.myname.mymodid.api apiPackage = # Specify the configuration file for Forge's access transformers here. It must be placed into /src/main/resources/META-INF/ -# There can be multiple files in a comma-separated list. -# Example value: mymodid_at.cfg,nei_at.cfg +# There can be multiple files in a space-separated list. +# Example value: mymodid_at.cfg nei_at.cfg accessTransformersFile = chickenchunks_at.cfg # Provides setup for Mixins if enabled. If you don't know what mixins are: Keep it disabled! usesMixins = false -# Adds some debug arguments like verbose output and export + +# Adds some debug arguments like verbose output and class export. usesMixinDebug = false + # Specify the location of your implementation of IMixinConfigPlugin. Leave it empty otherwise. mixinPlugin = + # Specify the package that contains all of your Mixins. You may only place Mixins in this package or the build will fail! mixinsPackage = + # Specify the core mod entry class if you use a core mod. This class must implement IFMLLoadingPlugin! # This parameter is for legacy compatibility only -# Example value: coreModClass = asm.FMLPlugin + modGroup = com.myname.mymodid -> com.myname.mymodid.asm.FMLPlugin +# Example value: (coreModClass = asm.FMLPlugin) + (modGroup = com.myname.mymodid) -> com.myname.mymodid.asm.FMLPlugin coreModClass = + # If your project is only a consolidation of mixins or a core mod and does NOT contain a 'normal' mod ( = some class # that is annotated with @Mod) you want this to be true. When in doubt: leave it on false! containsMixinsAndOrCoreModOnly = false @@ -79,22 +106,32 @@ containsMixinsAndOrCoreModOnly = false # Enables Mixins even if this mod doesn't use them, useful if one of the dependencies uses mixins. forceEnableMixins = false -# If enabled, you may use 'shadowCompile' for dependencies. They will be integrated in your jar. It is your -# responsibility check the licence and request permission for distribution, if required. +# If enabled, you may use 'shadowCompile' for dependencies. They will be integrated into your jar. It is your +# responsibility to check the license and request permission for distribution if required. usesShadowedDependencies = false -# If disabled, won't remove unused classes from shaded dependencies. Some libraries use reflection to access + +# If disabled, won't remove unused classes from shadowed dependencies. Some libraries use reflection to access # their own classes, making the minimization unreliable. minimizeShadowedDependencies = true + # If disabled, won't rename the shadowed classes. relocateShadowedDependencies = true -# Adds the GTNH maven, CurseMaven, IC2/Player maven, and some more well-known 1.7.10 repositories +# Adds the GTNH maven, CurseMaven, IC2/Player maven, and some more well-known 1.7.10 repositories. includeWellKnownRepositories = true -# Publishing to modrinth requires you to set the MODRINTH_TOKEN environment variable to your current modrinth API token. +# Change these to your Maven coordinates if you want to publish to a custom Maven repository instead of the default GTNH Maven. +# Authenticate with the MAVEN_USER and MAVEN_PASSWORD environment variables. +# If you need a more complex setup disable maven publishing here and add a publishing repository to addon.gradle. +usesMavenPublishing = true + +# Maven repository to publish the mod to. +# mavenPublishUrl = https\://nexus.gtnewhorizons.com/repository/releases/ +# Publishing to Modrinth requires you to set the MODRINTH_TOKEN environment variable to your current Modrinth API token. +# # The project's ID on Modrinth. Can be either the slug or the ID. -# Leave this empty if you don't want to publish on Modrinth. +# Leave this empty if you don't want to publish to Modrinth. modrinthProjectId = # The project's relations on Modrinth. You can use this to refer to other projects on Modrinth. @@ -106,9 +143,8 @@ modrinthProjectId = # Note: GTNH Mixins is automatically set as a required dependency if usesMixins = true modrinthRelations = - # Publishing to CurseForge requires you to set the CURSEFORGE_TOKEN environment variable to one of your CurseForge API tokens. - +# # The project's numeric ID on CurseForge. You can find this in the About Project box. # Leave this empty if you don't want to publish on CurseForge. curseForgeProjectId = @@ -118,26 +154,39 @@ curseForgeProjectId = # Where type can be one of [requiredDependency, embeddedLibrary, optionalDependency, tool, incompatible], # and the name is the CurseForge project slug of the other mod. # Example: requiredDependency:railcraft;embeddedLibrary:cofhlib;incompatible:buildcraft -# Note: GTNH Mixins is automatically set as a required dependency if usesMixins = true +# Note: UniMixins is automatically set as a required dependency if usesMixins = true. curseForgeRelations = - -# Optional parameter to customize the produced artifacts. Use this to preserver artifact naming when migrating older +# Optional parameter to customize the produced artifacts. Use this to preserve artifact naming when migrating older # projects. New projects should not use this parameter. # customArchiveBaseName = -# Optional parameter to prevent the source code from being published -# noPublishedSources = +# Optional parameter to have the build automatically fail if an illegal version is used. +# This can be useful if you e.g. only want to allow versions in the form of '1.1.xxx'. +# The check is ONLY performed if the version is a git tag. +# Note: the specified string must be escaped, so e.g. 1\\.1\\.\\d+ instead of 1\.1\.\d+ +# versionPattern = + +# Uncomment to prevent the source code from being published. +# noPublishedSources = true -# Uncomment this to disable spotless checks +# Uncomment this to disable Spotless checks. # This should only be uncommented to keep it easier to sync with upstream/other forks. # That is, if there is no other active fork/upstream, NEVER change this. # disableSpotless = true -# Override the IDEA build type. Valid value is "" (leave blank, do not override), "idea" (force use native IDEA build), "gradle" +# Uncomment this to disable Checkstyle checks (currently wildcard import check). +# disableCheckstyle = true + +# Override the IDEA build type. Valid values are: "" (leave blank, do not override), "idea" (force use native IDEA build), "gradle" # (force use delegated build). # This is meant to be set in $HOME/.gradle/gradle.properties. -# e.g. add "systemProp.org.gradle.project.ideaOverrideBuildType=idea" will override the build type to be always native build. +# e.g. add "systemProp.org.gradle.project.ideaOverrideBuildType=idea" will override the build type to be native build. # WARNING: If you do use this option, it will overwrite whatever you have in your existing projects. This might not be what you want! # Usually there is no need to uncomment this here as other developers do not necessarily use the same build type as you. # ideaOverrideBuildType = idea + +# Whether IDEA should run spotless checks when pressing the Build button. +# This is meant to be set in $HOME/.gradle/gradle.properties. +# ideaCheckSpotlessOnBuild = true + diff --git a/gradle/wrapper/gradle-wrapper.jar b/gradle/wrapper/gradle-wrapper.jar index ccebba7..d64cd49 100644 Binary files a/gradle/wrapper/gradle-wrapper.jar and b/gradle/wrapper/gradle-wrapper.jar differ diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties index 3499ded..a80b22c 100644 --- a/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,7 @@ distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-8.5-bin.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-8.6-bin.zip networkTimeout=10000 +validateDistributionUrl=true zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists diff --git a/gradlew b/gradlew index 79a61d4..1aa94a4 100644 --- a/gradlew +++ b/gradlew @@ -83,10 +83,8 @@ done # This is normally unused # shellcheck disable=SC2034 APP_BASE_NAME=${0##*/} -APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit - -# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. -DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' +# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036) +APP_HOME=$( cd "${APP_HOME:-./}" > /dev/null && pwd -P ) || exit # Use the maximum available, or set MAX_FD != -1 to use that value. MAX_FD=maximum @@ -133,10 +131,13 @@ location of your Java installation." fi else JAVACMD=java - which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. + if ! command -v java >/dev/null 2>&1 + then + die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. Please set the JAVA_HOME variable in your environment to match the location of your Java installation." + fi fi # Increase the maximum file descriptors if we can. @@ -144,7 +145,7 @@ if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then case $MAX_FD in #( max*) # In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked. - # shellcheck disable=SC3045 + # shellcheck disable=SC2039,SC3045 MAX_FD=$( ulimit -H -n ) || warn "Could not query maximum file descriptor limit" esac @@ -152,7 +153,7 @@ if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then '' | soft) :;; #( *) # In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked. - # shellcheck disable=SC3045 + # shellcheck disable=SC2039,SC3045 ulimit -n "$MAX_FD" || warn "Could not set maximum file descriptor limit to $MAX_FD" esac @@ -197,11 +198,15 @@ if "$cygwin" || "$msys" ; then done fi -# Collect all arguments for the java command; -# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of -# shell script including quotes and variable substitutions, so put them in -# double quotes to make sure that they get re-expanded; and -# * put everything else in single quotes, so that it's not re-expanded. + +# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' + +# Collect all arguments for the java command: +# * DEFAULT_JVM_OPTS, JAVA_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments, +# and any embedded shellness will be escaped. +# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be +# treated as '${Hostname}' itself on the command line. set -- \ "-Dorg.gradle.appname=$APP_BASE_NAME" \ diff --git a/gradlew.bat b/gradlew.bat index 93e3f59..25da30d 100644 --- a/gradlew.bat +++ b/gradlew.bat @@ -43,11 +43,11 @@ set JAVA_EXE=java.exe %JAVA_EXE% -version >NUL 2>&1 if %ERRORLEVEL% equ 0 goto execute -echo. -echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. -echo. -echo Please set the JAVA_HOME variable in your environment to match the -echo location of your Java installation. +echo. 1>&2 +echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2 +echo. 1>&2 +echo Please set the JAVA_HOME variable in your environment to match the 1>&2 +echo location of your Java installation. 1>&2 goto fail @@ -57,11 +57,11 @@ set JAVA_EXE=%JAVA_HOME%/bin/java.exe if exist "%JAVA_EXE%" goto execute -echo. -echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% -echo. -echo Please set the JAVA_HOME variable in your environment to match the -echo location of your Java installation. +echo. 1>&2 +echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2 +echo. 1>&2 +echo Please set the JAVA_HOME variable in your environment to match the 1>&2 +echo location of your Java installation. 1>&2 goto fail diff --git a/repositories.gradle b/repositories.gradle index c884390..7e002f2 100644 --- a/repositories.gradle +++ b/repositories.gradle @@ -1,4 +1,4 @@ -// Add any additional repositories for your dependencies here +// Add any additional repositories for your dependencies here. repositories { diff --git a/settings.gradle b/settings.gradle index 01ea5f1..69d2d74 100644 --- a/settings.gradle +++ b/settings.gradle @@ -4,10 +4,10 @@ pluginManagement { maven { // RetroFuturaGradle name "GTNH Maven" - url "http://jenkins.usrv.eu:8081/nexus/content/groups/public/" - allowInsecureProtocol = true + url "https://nexus.gtnewhorizons.com/repository/public/" mavenContent { - includeGroup("com.gtnewhorizons.retrofuturagradle") + includeGroup("com.gtnewhorizons") + includeGroupByRegex("com\\.gtnewhorizons\\..+") } } gradlePluginPortal() @@ -17,12 +17,5 @@ pluginManagement { } plugins { - id 'com.diffplug.blowdryerSetup' version '1.6.0' - id 'org.gradle.toolchains.foojay-resolver-convention' version '0.4.0' // Provides java toolchains -} - -blowdryerSetup { - repoSubfolder 'gtnhShared' - github('GTNewHorizons/ExampleMod1.7.10', 'tag', '0.2.0') - //devLocal '.' // Use this when testing config updates locally + id 'com.gtnewhorizons.gtnhsettingsconvention' version '1.0.14' } diff --git a/src/main/java/codechicken/chunkloader/BlockChunkLoader.java b/src/main/java/codechicken/chunkloader/BlockChunkLoader.java index b9be941..6b8b668 100644 --- a/src/main/java/codechicken/chunkloader/BlockChunkLoader.java +++ b/src/main/java/codechicken/chunkloader/BlockChunkLoader.java @@ -48,7 +48,7 @@ public void setBlockBoundsBasedOnState(IBlockAccess world, int x, int y, int z) @Override public void addCollisionBoxesToList(World world, int x, int y, int z, AxisAlignedBB par5AxisAlignedBB, - List par6List, Entity par7Entity) { + List par6List, Entity par7Entity) { setBlockBoundsBasedOnState(world, x, y, z); super.addCollisionBoxesToList(world, x, y, z, par5AxisAlignedBB, par6List, par7Entity); } @@ -83,9 +83,10 @@ public IIcon getIcon(int side, int meta) { @Override public boolean onBlockActivated(World world, int x, int y, int z, EntityPlayer player, int par6, float par7, - float par8, float par9) { + float par8, float par9) { if (!world.blockExists(x, y, z)) { - world.getChunkProvider().loadChunk(x >> 4, z >> 4); + world.getChunkProvider() + .loadChunk(x >> 4, z >> 4); } int meta = world.getBlockMetadata(x, y, z); @@ -94,8 +95,8 @@ public boolean onBlockActivated(World world, int x, int y, int z, EntityPlayer p if (!world.isRemote) { TileChunkLoader tile = (TileChunkLoader) world.getTileEntity(x, y, z); if (tile.owner == null - || (ChunkLoaderManager.userInteract() && tile.owner.equals(player.getCommandSenderName())) - || ChunkLoaderManager.opInteract() && ServerUtils.isPlayerOP(player.getCommandSenderName())) { + || (ChunkLoaderManager.userInteract() && tile.owner.equals(player.getCommandSenderName())) + || ChunkLoaderManager.opInteract() && ServerUtils.isPlayerOP(player.getCommandSenderName())) { PacketCustom packet = new PacketCustom(ChunkLoaderSPH.channel, 12); packet.writeCoord(x, y, z); packet.sendToPlayer(player); diff --git a/src/main/java/codechicken/chunkloader/ChickenChunks.java b/src/main/java/codechicken/chunkloader/ChickenChunks.java index c9b4740..8425d12 100644 --- a/src/main/java/codechicken/chunkloader/ChickenChunks.java +++ b/src/main/java/codechicken/chunkloader/ChickenChunks.java @@ -13,16 +13,16 @@ import cpw.mods.fml.common.event.FMLServerStartingEvent; @Mod( - modid = Tags.MODID, - name = Tags.MODNAME, - version = Tags.VERSION, - dependencies = "after:CodeChickenCore", - acceptedMinecraftVersions = CodeChickenCorePlugin.mcVersion) + modid = Tags.MODID, + name = Tags.MODNAME, + version = Tags.VERSION, + dependencies = "after:CodeChickenCore", + acceptedMinecraftVersions = CodeChickenCorePlugin.mcVersion) public class ChickenChunks { @SidedProxy( - clientSide = "codechicken.chunkloader.ChunkLoaderClientProxy", - serverSide = "codechicken.chunkloader.ChunkLoaderProxy") + clientSide = "codechicken.chunkloader.ChunkLoaderClientProxy", + serverSide = "codechicken.chunkloader.ChunkLoaderProxy") public static ChunkLoaderProxy proxy; public static ConfigFile config; @@ -35,7 +35,7 @@ public class ChickenChunks { @EventHandler public void preInit(FMLPreInitializationEvent event) { config = new ConfigFile(new File(event.getModConfigurationDirectory(), "ChickenChunks.cfg")).setComment( - "ChunkLoader Configuration File\nDeleting any element will restore it to it's default value\nBlock ID's will be automatically generated the first time it's run"); + "ChunkLoader Configuration File\nDeleting any element will restore it to it's default value\nBlock ID's will be automatically generated the first time it's run"); } @EventHandler diff --git a/src/main/java/codechicken/chunkloader/ChunkLoaderCPH.java b/src/main/java/codechicken/chunkloader/ChunkLoaderCPH.java index d7c037c..390207e 100644 --- a/src/main/java/codechicken/chunkloader/ChunkLoaderCPH.java +++ b/src/main/java/codechicken/chunkloader/ChunkLoaderCPH.java @@ -20,40 +20,47 @@ public void handlePacket(PacketCustom packet, Minecraft mc, INetHandlerPlayClien switch (packet.getType()) { case 1: PlayerChunkViewer.openViewer( - (int) mc.thePlayer.posX, - (int) mc.thePlayer.posZ, - CommonUtils.getDimension(mc.theWorld)); + (int) mc.thePlayer.posX, + (int) mc.thePlayer.posZ, + CommonUtils.getDimension(mc.theWorld)); break; case 2: - PlayerChunkViewer.instance().loadDimension(packet, mc.theWorld); + PlayerChunkViewer.instance() + .loadDimension(packet, mc.theWorld); break; case 3: - PlayerChunkViewer.instance().unloadDimension(packet.readInt()); + PlayerChunkViewer.instance() + .unloadDimension(packet.readInt()); break; case 4: - PlayerChunkViewer.instance().handleChunkChange( + PlayerChunkViewer.instance() + .handleChunkChange( packet.readInt(), new ChunkCoordIntPair(packet.readInt(), packet.readInt()), packet.readBoolean()); break; case 5: - PlayerChunkViewer.instance().handleTicketChange( + PlayerChunkViewer.instance() + .handleTicketChange( packet.readInt(), packet.readInt(), new ChunkCoordIntPair(packet.readInt(), packet.readInt()), packet.readBoolean()); break; case 6: - PlayerChunkViewer.instance().handlePlayerUpdate( + PlayerChunkViewer.instance() + .handlePlayerUpdate( packet.readString(), packet.readInt(), new Vector3(packet.readFloat(), packet.readFloat(), packet.readFloat())); break; case 7: - PlayerChunkViewer.instance().removePlayer(packet.readString()); + PlayerChunkViewer.instance() + .removePlayer(packet.readString()); break; case 8: - PlayerChunkViewer.instance().handleNewTicket(packet, mc.theWorld); + PlayerChunkViewer.instance() + .handleNewTicket(packet, mc.theWorld); break; case 10: TileChunkLoader.handleDescriptionPacket(packet, mc.theWorld); diff --git a/src/main/java/codechicken/chunkloader/ChunkLoaderClientProxy.java b/src/main/java/codechicken/chunkloader/ChunkLoaderClientProxy.java index a069456..5c112dd 100644 --- a/src/main/java/codechicken/chunkloader/ChunkLoaderClientProxy.java +++ b/src/main/java/codechicken/chunkloader/ChunkLoaderClientProxy.java @@ -14,7 +14,8 @@ public class ChunkLoaderClientProxy extends ChunkLoaderProxy { @Override public void init() { - if (config.getTag("checkUpdates").getBooleanValue(true)) CCUpdateChecker.updateCheck("ChickenChunks"); + if (config.getTag("checkUpdates") + .getBooleanValue(true)) CCUpdateChecker.updateCheck("ChickenChunks"); ClientUtils.enhanceSupportersList("ChickenChunks"); super.init(); @@ -28,6 +29,7 @@ public void init() { @Override public void openGui(TileChunkLoader tile) { - Minecraft.getMinecraft().displayGuiScreen(new GuiChunkLoader(tile)); + Minecraft.getMinecraft() + .displayGuiScreen(new GuiChunkLoader(tile)); } } diff --git a/src/main/java/codechicken/chunkloader/ChunkLoaderEventHandler.java b/src/main/java/codechicken/chunkloader/ChunkLoaderEventHandler.java index 0178880..4c9d20c 100644 --- a/src/main/java/codechicken/chunkloader/ChunkLoaderEventHandler.java +++ b/src/main/java/codechicken/chunkloader/ChunkLoaderEventHandler.java @@ -22,14 +22,16 @@ public class ChunkLoaderEventHandler { @SubscribeEvent public void serverTick(ServerTickEvent event) { - if (event.phase == Phase.END) PlayerChunkViewerManager.instance().update(); + if (event.phase == Phase.END) PlayerChunkViewerManager.instance() + .update(); } @SubscribeEvent public void worldTick(WorldTickEvent event) { if (event.phase == Phase.END && !event.world.isRemote) { ChunkLoaderManager.tickEnd((WorldServer) event.world); - PlayerChunkViewerManager.instance().calculateChunkChanges((WorldServer) event.world); + PlayerChunkViewerManager.instance() + .calculateChunkChanges((WorldServer) event.world); } } @@ -61,10 +63,11 @@ public void onWorldLoad(Load event) { @SubscribeEvent public void onWorldUnload(Unload event) { if (!event.world.isRemote) { - if (ServerUtils.mc().isServerRunning()) { + if (ServerUtils.mc() + .isServerRunning()) { ChunkLoaderManager.unloadWorld(event.world); PlayerChunkViewerManager.instance().dimChanges - .add(new DimensionChange((WorldServer) event.world, false)); + .add(new DimensionChange((WorldServer) event.world, false)); } else { PlayerChunkViewerManager.serverShutdown(); ChunkLoaderManager.serverShutdown(); diff --git a/src/main/java/codechicken/chunkloader/ChunkLoaderManager.java b/src/main/java/codechicken/chunkloader/ChunkLoaderManager.java index 91b6de8..fe08d43 100644 --- a/src/main/java/codechicken/chunkloader/ChunkLoaderManager.java +++ b/src/main/java/codechicken/chunkloader/ChunkLoaderManager.java @@ -103,7 +103,8 @@ protected void addChunk(DimChunkCoord coord) { ForgeChunkManager.forceChunk(ticket, coord.getChunkCoord()); heldChunks.put(coord, ticket); - if (ticket.getChunkList().size() == ticket.getChunkListDepth() && !freeTickets.isEmpty()) freeTickets.pop(); + if (ticket.getChunkList() + .size() == ticket.getChunkListDepth() && !freeTickets.isEmpty()) freeTickets.pop(); } protected abstract Ticket createTicket(int dimension); @@ -114,7 +115,8 @@ protected void remChunk(DimChunkCoord coord) { ForgeChunkManager.unforceChunk(ticket, coord.getChunkCoord()); - if (ticket.getChunkList().size() == ticket.getChunkListDepth() - 1) { + if (ticket.getChunkList() + .size() == ticket.getChunkListDepth() - 1) { Stack freeTickets = ticketsWithSpace.get(coord.dimension); if (freeTickets == null) ticketsWithSpace.put(coord.dimension, freeTickets = new Stack()); freeTickets.push(ticket); @@ -180,7 +182,7 @@ public void remChunkLoader(IChickenChunkLoader loader) { } private void unforceChunks(IChickenChunkLoader loader, int dim, Collection chunks, - boolean remLoader) { + boolean remLoader) { for (ChunkCoordIntPair coord : chunks) { DimChunkCoord dimCoord = new DimChunkCoord(dim, coord); LinkedList loaders = forcedChunksByChunk.get(dimCoord); @@ -192,7 +194,8 @@ private void unforceChunks(IChickenChunkLoader loader, int dim, Collection> 4, coord.z >> 4); + world.getChunkProvider() + .loadChunk(coord.x >> 4, coord.z >> 4); } TileEntity tile = world.getTileEntity(coord.x, coord.y, coord.z); reviving = false; @@ -327,8 +332,8 @@ public boolean isDormant() { } public void tickDownUnloads() { - for (Iterator> iterator = timedUnloadQueue.entrySet().iterator(); iterator - .hasNext();) { + for (Iterator> iterator = timedUnloadQueue.entrySet() + .iterator(); iterator.hasNext();) { Entry entry = iterator.next(); int ticks = entry.getValue(); if (ticks <= 1) { @@ -353,17 +358,17 @@ public PlayerOrganiser(String username) { public boolean canForceNewChunks(int required, int dim) { return required + numLoadedChunks() < getPlayerChunkLimit(username) - && required < ForgeChunkManager.ticketCountAvailableFor(username) - * ForgeChunkManager.getMaxChunkDepthFor("ChickenChunks"); + && required < ForgeChunkManager.ticketCountAvailableFor(username) + * ForgeChunkManager.getMaxChunkDepthFor("ChickenChunks"); } @Override public Ticket createTicket(int dimension) { return ForgeChunkManager.requestPlayerTicket( - ChickenChunks.instance, - username, - DimensionManager.getWorld(dimension), - Type.NORMAL); + ChickenChunks.instance, + username, + DimensionManager.getWorld(dimension), + Type.NORMAL); } @Override @@ -386,7 +391,7 @@ public ModOrganiser(Object mod, ModContainer container) { @Override public boolean canForceNewChunks(int required, int dim) { return required < ForgeChunkManager.ticketCountAvailableFor(mod, DimensionManager.getWorld(dim)) - * ForgeChunkManager.getMaxChunkDepthFor(container.getModId()); + * ForgeChunkManager.getMaxChunkDepthFor(container.getModId()); } @Override @@ -449,7 +454,10 @@ public static void load() { * By doing this you are delegating all chunks from your mod to be handled by yours truly. */ public static void registerMod(Object mod) { - ModContainer container = Loader.instance().getModObjectList().inverse().get(mod); + ModContainer container = Loader.instance() + .getModObjectList() + .inverse() + .get(mod); if (container == null) throw new NullPointerException("Mod container not found for: " + mod); mods.put(mod, container); ForgeChunkManager.setForcedChunkLoadingCallback(mod, new DummyLoadingCallback()); @@ -460,7 +468,8 @@ public static void loadWorld(WorldServer world) { } public static World getWorld(int dim, boolean create) { - if (create) return MinecraftServer.getServer().worldServerForDimension(dim); + if (create) return MinecraftServer.getServer() + .worldServerForDimension(dim); return DimensionManager.getWorld(dim); } @@ -494,7 +503,8 @@ private static void loadLoginTimes() throws IOException { int entries = datain.readInt(); for (int i = 0; i < entries; i++) loginTimes.put(datain.readUTF(), datain.readLong()); } catch (IOException e) { - LogManager.getLogger("ChickenChunks").error("Error reading loginTimes.dat", e); + LogManager.getLogger("ChickenChunks") + .error("Error reading loginTimes.dat", e); } datain.close(); @@ -502,7 +512,10 @@ private static void loadLoginTimes() throws IOException { private static void loadModChunks() throws IOException { for (Entry entry : mods.entrySet()) { - File saveFile = new File(saveDir, entry.getValue().getModId() + ".dat"); + File saveFile = new File( + saveDir, + entry.getValue() + .getModId() + ".dat"); if (!saveFile.exists()) return; DataInputStream datain = new DataInputStream(new FileInputStream(saveFile)); @@ -542,69 +555,101 @@ private static boolean loggedInRecently(String username) { public static int getPlayerChunkLimit(String username) { ConfigTag config = ChickenChunks.config.getTag("players"); if (config.containsTag(username)) { - int ret = config.getTag(username).getIntValue(0); + int ret = config.getTag(username) + .getIntValue(0); if (ret != 0) return ret; } if (ServerUtils.isPlayerOP(username)) { - int ret = config.getTag("OP").getIntValue(0); + int ret = config.getTag("OP") + .getIntValue(0); if (ret != 0) return ret; } - return config.getTag("DEFAULT").getIntValue(5000); + return config.getTag("DEFAULT") + .getIntValue(5000); } public static boolean allowOffline(String username) { ConfigTag config = ChickenChunks.config.getTag("allowoffline"); - if (config.containsTag(username)) return config.getTag(username).getBooleanValue(true); + if (config.containsTag(username)) return config.getTag(username) + .getBooleanValue(true); - if (ServerUtils.isPlayerOP(username)) return config.getTag("OP").getBooleanValue(true); + if (ServerUtils.isPlayerOP(username)) return config.getTag("OP") + .getBooleanValue(true); - return config.getTag("DEFAULT").getBooleanValue(true); + return config.getTag("DEFAULT") + .getBooleanValue(true); } public static boolean allowChunkViewer(String username) { ConfigTag config = ChickenChunks.config.getTag("allowchunkviewer"); - if (config.containsTag(username)) return config.getTag(username).getBooleanValue(true); + if (config.containsTag(username)) return config.getTag(username) + .getBooleanValue(true); - if (ServerUtils.isPlayerOP(username)) return config.getTag("OP").getBooleanValue(true); + if (ServerUtils.isPlayerOP(username)) return config.getTag("OP") + .getBooleanValue(true); - return config.getTag("DEFAULT").getBooleanValue(true); + return config.getTag("DEFAULT") + .getBooleanValue(true); } public static void initConfig(ConfigFile config) { - config.getTag("players").setPosition(0).useBraces() - .setComment("Per player chunk limiting. Values ignored if 0.:Simply add ="); - config.getTag("players.DEFAULT").setComment("Forge gives everyone 12500 by default").getIntValue(5000); - config.getTag("players.OP").setComment("For server op's only.").getIntValue(5000); - config.getTag("allowoffline").setPosition(1).useBraces().setComment( + config.getTag("players") + .setPosition(0) + .useBraces() + .setComment("Per player chunk limiting. Values ignored if 0.:Simply add ="); + config.getTag("players.DEFAULT") + .setComment("Forge gives everyone 12500 by default") + .getIntValue(5000); + config.getTag("players.OP") + .setComment("For server op's only.") + .getIntValue(5000); + config.getTag("allowoffline") + .setPosition(1) + .useBraces() + .setComment( "If set to false, players will have to be logged in for their chunkloaders to work.:Simply add ="); - config.getTag("allowoffline.DEFAULT").getBooleanValue(true); - config.getTag("allowoffline.OP").getBooleanValue(true); - config.getTag("allowchunkviewer").setPosition(2).useBraces() - .setComment("Set to false to deny a player access to the chunk viewer"); - config.getTag("allowchunkviewer.DEFAULT").getBooleanValue(true); - config.getTag("allowchunkviewer.OP").getBooleanValue(true); - if (!FMLCommonHandler.instance().getModName().contains("mcpc")) cleanupTicks = config.getTag("cleanuptime") + config.getTag("allowoffline.DEFAULT") + .getBooleanValue(true); + config.getTag("allowoffline.OP") + .getBooleanValue(true); + config.getTag("allowchunkviewer") + .setPosition(2) + .useBraces() + .setComment("Set to false to deny a player access to the chunk viewer"); + config.getTag("allowchunkviewer.DEFAULT") + .getBooleanValue(true); + config.getTag("allowchunkviewer.OP") + .getBooleanValue(true); + if (!FMLCommonHandler.instance() + .getModName() + .contains("mcpc")) + cleanupTicks = config.getTag("cleanuptime") .setComment("The number of ticks to wait between attempting to unload orphaned chunks") .getIntValue(1200); reloadDimensions = config.getTag("reload-dimensions") - .setComment("Set to false to disable the automatic reloading of mystcraft dimensions on server restart") - .getBooleanValue(true); - opInteract = config.getTag("op-interact").setComment( + .setComment("Set to false to disable the automatic reloading of mystcraft dimensions on server restart") + .getBooleanValue(true); + opInteract = config.getTag("op-interact") + .setComment( "Enabling this lets OPs alter other player's chunkloaders. WARNING: If you change a chunkloader, you have no idea what may break/explode by not being chunkloaded.") - .getBooleanValue(false); - userInteract = config.getTag("user-interact").setComment( + .getBooleanValue(false); + userInteract = config.getTag("user-interact") + .setComment( "Disabling this lets normal non-OP player's never open any chunkloader, also not their own. WARNING: Only to be used if 'op-interact' is true to ensure only admins can control chunk loaders.") - .getBooleanValue(true); - allowOwnerChange = config.getTag("allow-owner-change").setComment( + .getBooleanValue(true); + allowOwnerChange = config.getTag("allow-owner-change") + .setComment( "Enabling this enables the option to change the owner of a Chunkloader. By default only the owner can change it. In case of 'user-interact' is false, only OPs can edit them. WARNING: If you change a owner of a chunkloader, you have no idea what may break/explode.") - .getBooleanValue(false); - maxChunks = config.getTag("maxchunks").setComment("The maximum number of chunks per chunkloader") - .getIntValue(400); - awayTimeout = config.getTag("awayTimeout").setComment( + .getBooleanValue(false); + maxChunks = config.getTag("maxchunks") + .setComment("The maximum number of chunks per chunkloader") + .getIntValue(400); + awayTimeout = config.getTag("awayTimeout") + .setComment( "The number of minutes since last login within which chunks from a player will remain active, 0 for infinite.") - .getIntValue(0); + .getIntValue(0); } public static void addChunkLoader(IChickenChunkLoader loader) { @@ -689,7 +734,9 @@ public static void save(WorldServer world) { @SuppressWarnings("unchecked") public static void cleanChunks(WorldServer world) { int dim = CommonUtils.getDimension(world); - int viewdist = ServerUtils.mc().getConfigurationManager().getViewDistance(); + int viewdist = ServerUtils.mc() + .getConfigurationManager() + .getViewDistance(); HashSet loadedChunks = new HashSet(); for (EntityPlayer player : ServerUtils.getPlayersInDimension(dim)) { @@ -707,7 +754,7 @@ public static void cleanChunks(WorldServer world) { for (Chunk chunk : (List) world.theChunkProviderServer.loadedChunks) { ChunkCoordIntPair coord = chunk.getChunkCoordIntPair(); if (!loadedChunks.contains(coord) && !persistantChunks.containsKey(coord) - && world.theChunkProviderServer.chunkExists(coord.chunkXPos, coord.chunkZPos)) { + && world.theChunkProviderServer.chunkExists(coord.chunkXPos, coord.chunkZPos)) { PlayerInstance instance = manager.getOrCreateChunkWatcher(coord.chunkXPos, coord.chunkZPos, false); if (instance == null) { world.theChunkProviderServer.unloadChunksIfNotNearSpawn(coord.chunkXPos, coord.chunkZPos); @@ -718,8 +765,11 @@ public static void cleanChunks(WorldServer world) { } } - if (ServerUtils.getPlayersInDimension(dim).isEmpty() && world.getPersistentChunks().isEmpty() - && !DimensionManager.shouldLoadSpawn(dim)) { + if (ServerUtils.getPlayersInDimension(dim) + .isEmpty() + && world.getPersistentChunks() + .isEmpty() + && !DimensionManager.shouldLoadSpawn(dim)) { DimensionManager.unloadWorld(dim); } } @@ -758,9 +808,11 @@ private static void updateLoginTimes() { } private static void tickDownUnloads() { - for (Entry entry : playerOrganisers.entrySet()) entry.getValue().tickDownUnloads(); + for (Entry entry : playerOrganisers.entrySet()) entry.getValue() + .tickDownUnloads(); - for (Entry entry : modOrganisers.entrySet()) entry.getValue().tickDownUnloads(); + for (Entry entry : modOrganisers.entrySet()) entry.getValue() + .tickDownUnloads(); } private static void revivePlayerLoaders() { diff --git a/src/main/java/codechicken/chunkloader/ChunkLoaderProxy.java b/src/main/java/codechicken/chunkloader/ChunkLoaderProxy.java index 8218d05..f72060a 100644 --- a/src/main/java/codechicken/chunkloader/ChunkLoaderProxy.java +++ b/src/main/java/codechicken/chunkloader/ChunkLoaderProxy.java @@ -18,7 +18,8 @@ public class ChunkLoaderProxy { public void init() { blockChunkLoader = new BlockChunkLoader(); - blockChunkLoader.setBlockName("chickenChunkLoader").setCreativeTab(CreativeTabs.tabMisc); + blockChunkLoader.setBlockName("chickenChunkLoader") + .setCreativeTab(CreativeTabs.tabMisc); GameRegistry.registerBlock(blockChunkLoader, ItemChunkLoader.class, "chickenChunkLoader"); GameRegistry.registerTileEntity(TileChunkLoader.class, "ChickenChunkLoader"); @@ -28,36 +29,39 @@ public void init() { ChunkLoaderManager.initConfig(config); MinecraftForge.EVENT_BUS.register(new ChunkLoaderEventHandler()); - FMLCommonHandler.instance().bus().register(new ChunkLoaderEventHandler()); + FMLCommonHandler.instance() + .bus() + .register(new ChunkLoaderEventHandler()); ChunkLoaderManager.registerMod(instance); GameRegistry.addRecipe( - new ItemStack(blockChunkLoader, 1, 0), - " p ", - "ggg", - "gEg", - 'p', - Items.ender_pearl, - 'g', - Items.gold_ingot, - 'd', - Items.diamond, - 'E', - Blocks.enchanting_table); + new ItemStack(blockChunkLoader, 1, 0), + " p ", + "ggg", + "gEg", + 'p', + Items.ender_pearl, + 'g', + Items.gold_ingot, + 'd', + Items.diamond, + 'E', + Blocks.enchanting_table); GameRegistry.addRecipe( - new ItemStack(blockChunkLoader, 10, 1), - "ppp", - "pcp", - "ppp", - 'p', - Items.ender_pearl, - 'c', - new ItemStack(blockChunkLoader, 1, 0)); + new ItemStack(blockChunkLoader, 10, 1), + "ppp", + "pcp", + "ppp", + 'p', + Items.ender_pearl, + 'c', + new ItemStack(blockChunkLoader, 1, 0)); } public void registerCommands(FMLServerStartingEvent event) { - CommandHandler commandManager = (CommandHandler) event.getServer().getCommandManager(); + CommandHandler commandManager = (CommandHandler) event.getServer() + .getCommandManager(); commandManager.registerCommand(new CommandChunkLoaders()); commandManager.registerCommand(new CommandDebugInfo()); } diff --git a/src/main/java/codechicken/chunkloader/ChunkLoaderSBRH.java b/src/main/java/codechicken/chunkloader/ChunkLoaderSBRH.java index 7682014..1629afa 100644 --- a/src/main/java/codechicken/chunkloader/ChunkLoaderSBRH.java +++ b/src/main/java/codechicken/chunkloader/ChunkLoaderSBRH.java @@ -24,7 +24,7 @@ public void renderInventoryBlock(Block block, int metadata, int modelID, RenderB @Override public boolean renderWorldBlock(IBlockAccess world, int x, int y, int z, Block block, int modelId, - RenderBlocks renderer) { + RenderBlocks renderer) { if (block != ChickenChunks.blockChunkLoader) return false; ChickenChunks.blockChunkLoader.setBlockBoundsBasedOnState(world, x, y, z); diff --git a/src/main/java/codechicken/chunkloader/ChunkLoaderSPH.java b/src/main/java/codechicken/chunkloader/ChunkLoaderSPH.java index df27c18..3ac1d75 100644 --- a/src/main/java/codechicken/chunkloader/ChunkLoaderSPH.java +++ b/src/main/java/codechicken/chunkloader/ChunkLoaderSPH.java @@ -16,7 +16,8 @@ public class ChunkLoaderSPH implements IServerPacketHandler { public void handlePacket(PacketCustom packet, EntityPlayerMP sender, INetHandlerPlayServer handler) { switch (packet.getType()) { case 1: - PlayerChunkViewerManager.instance().closeViewer(sender.getCommandSenderName()); + PlayerChunkViewerManager.instance() + .closeViewer(sender.getCommandSenderName()); break; case 2: handleChunkLoaderChangePacket(sender.worldObj, packet); diff --git a/src/main/java/codechicken/chunkloader/CommandChunkLoaders.java b/src/main/java/codechicken/chunkloader/CommandChunkLoaders.java index 1652ad3..6fe2afe 100644 --- a/src/main/java/codechicken/chunkloader/CommandChunkLoaders.java +++ b/src/main/java/codechicken/chunkloader/CommandChunkLoaders.java @@ -21,7 +21,8 @@ public String getCommandUsage(ICommandSender var1) { @Override public void handleCommand(WorldServer world, EntityPlayerMP player, String[] args) { WCommandSender wrapped = new WCommandSender(player); - if (PlayerChunkViewerManager.instance().isViewerOpen(player.getCommandSenderName())) { + if (PlayerChunkViewerManager.instance() + .isViewerOpen(player.getCommandSenderName())) { wrapped.chatT("command.chunkloaders.alreadyopen"); return; } diff --git a/src/main/java/codechicken/chunkloader/GuiChunkLoader.java b/src/main/java/codechicken/chunkloader/GuiChunkLoader.java index e86b50f..8fad6fd 100644 --- a/src/main/java/codechicken/chunkloader/GuiChunkLoader.java +++ b/src/main/java/codechicken/chunkloader/GuiChunkLoader.java @@ -44,7 +44,7 @@ public void initGui() { public void updateNames() { laserButton.displayString = tile.renderInfo.showLasers ? lang.translate("hidelasers") - : lang.translate("showlasers"); + : lang.translate("showlasers"); shapeButton.displayString = tile.shape.getName(); } @@ -127,7 +127,7 @@ private void drawContainerBackground() { private boolean enableOwner() { return ChunkLoaderManager.allowOwnerChange() && (!ChunkLoaderManager.userInteract() - || (ChunkLoaderManager.opInteract() && ServerUtils.isPlayerOP(this.tile.owner))); + || (ChunkLoaderManager.opInteract() && ServerUtils.isPlayerOP(this.tile.owner))); } public boolean doesGuiPauseGame() { diff --git a/src/main/java/codechicken/chunkloader/PlayerChunkViewer.java b/src/main/java/codechicken/chunkloader/PlayerChunkViewer.java index 81c8d08..5dbc782 100644 --- a/src/main/java/codechicken/chunkloader/PlayerChunkViewer.java +++ b/src/main/java/codechicken/chunkloader/PlayerChunkViewer.java @@ -124,9 +124,9 @@ public TicketInfoDialog(LinkedList tickets) { chunkPane.setContentType("text/html"); chunkScrollPane = new JScrollPane( - chunkPane, - ScrollPaneConstants.VERTICAL_SCROLLBAR_AS_NEEDED, - ScrollPaneConstants.HORIZONTAL_SCROLLBAR_NEVER); + chunkPane, + ScrollPaneConstants.VERTICAL_SCROLLBAR_AS_NEEDED, + ScrollPaneConstants.HORIZONTAL_SCROLLBAR_NEVER); add(chunkScrollPane); ticketComboBox = new JComboBox(); @@ -163,15 +163,15 @@ public void update() { if (ticket.player != null) info += "
Player: " + ticket.player; info += "
Type: " + ticket.type.name(); if (ticket.entity != null) info += "
Entity: " + EntityList.classToStringMapping.get(ticket.entity) - + "#" - + ticket.entity.getEntityId() - + " (" - + String.format("%.2f", ticket.entity.posX) - + ", " - + String.format("%.2f", ticket.entity.posY) - + ", " - + String.format("%.2f", ticket.entity.posZ) - + ")"; + + "#" + + ticket.entity.getEntityId() + + " (" + + String.format("%.2f", ticket.entity.posX) + + ", " + + String.format("%.2f", ticket.entity.posY) + + ", " + + String.format("%.2f", ticket.entity.posZ) + + ")"; info += "

ForcedChunks

"; String chunks = ""; for (ChunkCoordIntPair coord : ticket.chunkSet) chunks += coord.chunkXPos + ", " + coord.chunkZPos + "
"; @@ -235,7 +235,8 @@ private PlayerChunkViewer(int x, int z, int dim) { @Override public void windowClosing(WindowEvent e) { - if (Minecraft.getMinecraft().getNetHandler() != null) ChunkLoaderCPH.sendGuiClosing(); + if (Minecraft.getMinecraft() + .getNetHandler() != null) ChunkLoaderCPH.sendGuiClosing(); } }); @@ -272,14 +273,18 @@ public void layoutContainer(Container paramContainer) { public void addLayoutComponent(String paramString, Component paramComponent) {} }); - ToolTipManager.sharedInstance().setEnabled(true); - ToolTipManager.sharedInstance().setInitialDelay(0); - ToolTipManager.sharedInstance().setReshowDelay(100); + ToolTipManager.sharedInstance() + .setEnabled(true); + ToolTipManager.sharedInstance() + .setInitialDelay(0); + ToolTipManager.sharedInstance() + .setReshowDelay(100); addComponents(); pack(); setTitle("Chunk Viewer"); - Point p = GraphicsEnvironment.getLocalGraphicsEnvironment().getCenterPoint(); + Point p = GraphicsEnvironment.getLocalGraphicsEnvironment() + .getCenterPoint(); int width = 500; int height = 500; setCenter(x, z); @@ -327,7 +332,8 @@ protected void update() { if (dims.size() != dimComboBox.getItemCount()) needsReset = true; else { for (int index = 0; index < dimComboBox.getItemCount();) { - if (!dims.get(index).equals(dimComboBox.getItemAt(index))) { + if (!dims.get(index) + .equals(dimComboBox.getItemAt(index))) { needsReset = true; break; } @@ -427,7 +433,8 @@ public JComboBox getDimComboBox() { @Override public void actionPerformed(ActionEvent e) { - if (e.getActionCommand().equals("comboBoxChanged")) { + if (e.getActionCommand() + .equals("comboBoxChanged")) { if (dimComboBox.getSelectedItem() != null) dimension = (Integer) dimComboBox.getSelectedItem(); } } @@ -563,8 +570,8 @@ public void mouseExited(MouseEvent event) {} @Override public void mouseDragged(MouseEvent event) { setCenter( - (mouseClickedX - event.getX()) * 4 + centerClickedX, - (mouseClickedY - event.getY()) * 4 + centerClickedZ); + (mouseClickedX - event.getX()) * 4 + centerClickedX, + (mouseClickedY - event.getY()) * 4 + centerClickedZ); } public LinkedList getTicketsUnderMouse(DimensionChunkInfo dimInfo, Point mouse) { @@ -603,13 +610,13 @@ public void mouseMoved(MouseEvent event) { if (info.dimension == dimension) { Point pos = getChunkRenderPosition((int) info.position.x, 0, (int) info.position.z); if (new Rectangle(pos.x, pos.y, 4, 4).contains(mouse)) tip += "\n\n" + info.username - + "\n(" - + String.format("%.2f", info.position.x) - + ", " - + String.format("%.2f", info.position.y) - + ", " - + String.format("%.2f", info.position.z) - + ")"; + + "\n(" + + String.format("%.2f", info.position.x) + + ", " + + String.format("%.2f", info.position.y) + + ", " + + String.format("%.2f", info.position.z) + + ")"; } } setToolTipText(tip.length() > 0 ? tip : null); diff --git a/src/main/java/codechicken/chunkloader/PlayerChunkViewerManager.java b/src/main/java/codechicken/chunkloader/PlayerChunkViewerManager.java index 7b839af..af8cb34 100644 --- a/src/main/java/codechicken/chunkloader/PlayerChunkViewerManager.java +++ b/src/main/java/codechicken/chunkloader/PlayerChunkViewerManager.java @@ -81,7 +81,8 @@ public void update() { time++; for (String username : logouts) for (Iterator iterator = playerViewers.iterator(); iterator.hasNext();) - if (iterator.next().owner.getCommandSenderName().equals(username)) iterator.remove(); + if (iterator.next().owner.getCommandSenderName() + .equals(username)) iterator.remove(); for (String username : logouts) for (PlayerChunkViewerTracker tracker : playerViewers) tracker.removePlayer(username); @@ -160,8 +161,8 @@ public void calculateChunkChanges(WorldServer world) { } public boolean isViewerOpen(String username) { - for (PlayerChunkViewerTracker tracker : playerViewers) - if (tracker.owner.getCommandSenderName().equals(username)) return true; + for (PlayerChunkViewerTracker tracker : playerViewers) if (tracker.owner.getCommandSenderName() + .equals(username)) return true; return false; } @@ -172,6 +173,7 @@ public static void serverShutdown() { public void closeViewer(String username) { for (Iterator iterator = playerViewers.iterator(); iterator.hasNext();) - if (iterator.next().owner.getCommandSenderName().equals(username)) iterator.remove(); + if (iterator.next().owner.getCommandSenderName() + .equals(username)) iterator.remove(); } } diff --git a/src/main/java/codechicken/chunkloader/PlayerChunkViewerTracker.java b/src/main/java/codechicken/chunkloader/PlayerChunkViewerTracker.java index 07b9b37..1cc4820 100644 --- a/src/main/java/codechicken/chunkloader/PlayerChunkViewerTracker.java +++ b/src/main/java/codechicken/chunkloader/PlayerChunkViewerTracker.java @@ -45,7 +45,9 @@ public void writeTicketToPacket(PacketCustom packet, Ticket ticket, Collection> tickets = ForgeChunkManager.getPersistentChunksFor(world).inverse() - .asMap(); + Map> tickets = ForgeChunkManager.getPersistentChunksFor(world) + .inverse() + .asMap(); packet.writeInt(tickets.size()); for (Entry> entry : tickets.entrySet()) writeTicketToPacket(packet, entry.getKey(), entry.getValue()); diff --git a/src/main/java/codechicken/chunkloader/TileChunkLoader.java b/src/main/java/codechicken/chunkloader/TileChunkLoader.java index 9978bd9..0d198de 100644 --- a/src/main/java/codechicken/chunkloader/TileChunkLoader.java +++ b/src/main/java/codechicken/chunkloader/TileChunkLoader.java @@ -18,7 +18,8 @@ public static void handleDescriptionPacket(PacketCustom packet, World world) { int y = packet.readInt(); int z = packet.readInt(); if (!world.blockExists(x, y, z)) { - world.getChunkProvider().loadChunk(x >> 4, z >> 4); + world.getChunkProvider() + .loadChunk(x >> 4, z >> 4); } TileEntity tile = world.getTileEntity(x, y, z); if (tile instanceof TileChunkLoader) { @@ -97,7 +98,7 @@ public HashSet getChunks() { } public static HashSet getContainedChunks(ChunkLoaderShape shape, int xCoord, int zCoord, - int radius) { + int radius) { return shape.getLoadedChunks(xCoord >> 4, zCoord >> 4, radius - 1); } diff --git a/src/main/java/codechicken/chunkloader/TileChunkLoaderBase.java b/src/main/java/codechicken/chunkloader/TileChunkLoaderBase.java index b74f577..01c4856 100644 --- a/src/main/java/codechicken/chunkloader/TileChunkLoaderBase.java +++ b/src/main/java/codechicken/chunkloader/TileChunkLoaderBase.java @@ -36,15 +36,16 @@ public void validate() { public boolean isPowered() { return isPoweringTo(worldObj, xCoord, yCoord + 1, zCoord, 0) - || isPoweringTo(worldObj, xCoord, yCoord - 1, zCoord, 1) - || isPoweringTo(worldObj, xCoord, yCoord, zCoord + 1, 2) - || isPoweringTo(worldObj, xCoord, yCoord, zCoord - 1, 3) - || isPoweringTo(worldObj, xCoord + 1, yCoord, zCoord, 4) - || isPoweringTo(worldObj, xCoord - 1, yCoord, zCoord, 5); + || isPoweringTo(worldObj, xCoord, yCoord - 1, zCoord, 1) + || isPoweringTo(worldObj, xCoord, yCoord, zCoord + 1, 2) + || isPoweringTo(worldObj, xCoord, yCoord, zCoord - 1, 3) + || isPoweringTo(worldObj, xCoord + 1, yCoord, zCoord, 4) + || isPoweringTo(worldObj, xCoord - 1, yCoord, zCoord, 5); } public static boolean isPoweringTo(World world, int x, int y, int z, int side) { - return world.getBlock(x, y, z).isProvidingWeakPower(world, x, y, z, side) > 0; + return world.getBlock(x, y, z) + .isProvidingWeakPower(world, x, y, z, side) > 0; } public void invalidate() { diff --git a/src/main/java/codechicken/chunkloader/TileChunkLoaderRenderer.java b/src/main/java/codechicken/chunkloader/TileChunkLoaderRenderer.java index a5bc086..35a31c6 100644 --- a/src/main/java/codechicken/chunkloader/TileChunkLoaderRenderer.java +++ b/src/main/java/codechicken/chunkloader/TileChunkLoaderRenderer.java @@ -73,9 +73,9 @@ public void renderTileEntityAt(TileEntity tile, double d, double d1, double d2, rot = ClientUtils.getRenderTime() * active / 3F; Matrix4 pearlMat = CCModelLibrary.getRenderMatrix( - new Vector3(d + 0.5, d1 + height + (updown + 0.3) * active, d2 + 0.5), - new Rotation(rot, new Vector3(0, 1, 0)), - size); + new Vector3(d + 0.5, d1 + height + (updown + 0.3) * active, d2 + 0.5), + new Rotation(rot, new Vector3(0, 1, 0)), + size); GL11.glDisable(GL11.GL_LIGHTING); CCRenderState.changeTexture("chickenchunks:textures/hedronmap.png"); @@ -111,13 +111,13 @@ public Point2D.Double findIntersection(Line2D line1, Line2D line2) { public boolean ptOnLineInSegment(Point2D point, Line2D line) { return point.getX() >= Math.min(line.getX1(), line.getX2()) - && point.getX() <= Math.max(line.getX1(), line.getX2()) - && point.getY() >= Math.min(line.getY1(), line.getY2()) - && point.getY() <= Math.max(line.getY1(), line.getY2()); + && point.getX() <= Math.max(line.getX1(), line.getX2()) + && point.getY() >= Math.min(line.getY1(), line.getY2()) + && point.getY() <= Math.max(line.getY1(), line.getY2()); } public void drawRays(double d, double d1, double d2, double rotationAngle, double updown, int x, int y, int z, - Collection chunkSet) { + Collection chunkSet) { int cx = (x >> 4) << 4; int cz = (z >> 4) << 4; @@ -139,10 +139,10 @@ public void drawRays(double d, double d1, double d2, double rotationAngle, doubl } Line2D.Double[] rays = new Line2D.Double[] { - new Line2D.Double(center.x, center.y, center.x + 1600 * absRays[0].x, center.y + 1600 * absRays[0].y), - new Line2D.Double(center.x, center.y, center.x + 1600 * absRays[1].x, center.y + 1600 * absRays[1].y), - new Line2D.Double(center.x, center.y, center.x + 1600 * absRays[2].x, center.y + 1600 * absRays[2].y), - new Line2D.Double(center.x, center.y, center.x + 1600 * absRays[3].x, center.y + 1600 * absRays[3].y) }; + new Line2D.Double(center.x, center.y, center.x + 1600 * absRays[0].x, center.y + 1600 * absRays[0].y), + new Line2D.Double(center.x, center.y, center.x + 1600 * absRays[1].x, center.y + 1600 * absRays[1].y), + new Line2D.Double(center.x, center.y, center.x + 1600 * absRays[2].x, center.y + 1600 * absRays[2].y), + new Line2D.Double(center.x, center.y, center.x + 1600 * absRays[3].x, center.y + 1600 * absRays[3].y) }; for (ChunkCoordIntPair pair : chunkSet) { int chunkBlockX = pair.chunkXPos << 4; @@ -151,10 +151,10 @@ public void drawRays(double d, double d1, double d2, double rotationAngle, doubl int[] offset1 = coords[side]; int[] offset2 = coords[(side + 1) % 4]; Line2D.Double line1 = new Line2D.Double( - chunkBlockX + offset1[0], - chunkBlockZ + offset1[1], - chunkBlockX + offset2[0], - chunkBlockZ + offset2[1]); + chunkBlockX + offset1[0], + chunkBlockZ + offset1[1], + chunkBlockX + offset2[0], + chunkBlockZ + offset2[1]); for (int ray = 0; ray < 4; ray++) { Point2D.Double isct = findIntersection(line1, rays[ray]); if (isct == null) continue; diff --git a/src/main/java/codechicken/chunkloader/TileSpotLoader.java b/src/main/java/codechicken/chunkloader/TileSpotLoader.java index 1531e69..6ab9b71 100644 --- a/src/main/java/codechicken/chunkloader/TileSpotLoader.java +++ b/src/main/java/codechicken/chunkloader/TileSpotLoader.java @@ -37,7 +37,7 @@ public Collection getChunks() { } public static HashSet getContainedChunks(ChunkLoaderShape shape, int xCoord, int zCoord, - int radius) { + int radius) { return shape.getLoadedChunks(xCoord >> 4, zCoord >> 4, radius - 1); } }