-
-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
15 changed files
with
341 additions
and
278 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
github: buuz135 | ||
patreon: buuz135 | ||
ko_fi: buuz135 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,193 +1,174 @@ | ||
buildscript { | ||
repositories { | ||
// These repositories are only for Gradle plugins, put any other repositories in the repository block further below | ||
maven { url = 'https://maven.minecraftforge.net' } | ||
maven { url = 'https://repo.spongepowered.org/repository/maven-public/' } | ||
mavenCentral() | ||
} | ||
dependencies { | ||
classpath group: 'net.minecraftforge.gradle', name: 'ForgeGradle', version: '5.1.+', changing: true | ||
classpath 'org.spongepowered:mixingradle:0.7-SNAPSHOT' | ||
} | ||
plugins { | ||
id 'java-library' | ||
id 'eclipse' | ||
id 'idea' | ||
id 'maven-publish' | ||
id 'net.neoforged.gradle.userdev' version '7.0.145' | ||
} | ||
|
||
apply plugin: 'net.minecraftforge.gradle' | ||
apply plugin: 'org.spongepowered.mixin' | ||
tasks.named('wrapper', Wrapper).configure { | ||
// Define wrapper values here so as to not have to always do so when updating gradlew.properties. | ||
// Switching this to Wrapper.DistributionType.ALL will download the full gradle sources that comes with | ||
// documentation attached on cursor hover of gradle classes and methods. However, this comes with increased | ||
// file size for Gradle. If you do switch this to ALL, run the Gradle wrapper task twice afterwards. | ||
// (Verify by checking gradle/wrapper/gradle-wrapper.properties to see if distributionUrl now points to `-all`) | ||
distributionType = Wrapper.DistributionType.BIN | ||
} | ||
|
||
group = 'com.buuz135' | ||
version = '1.20.1-1.2.1' | ||
version = mod_version | ||
group = mod_group_id | ||
|
||
repositories { | ||
mavenLocal() | ||
} | ||
|
||
java { | ||
archivesBaseName = 'DarkModeEverywhere' | ||
toolchain.languageVersion = JavaLanguageVersion.of(17) | ||
base { | ||
archivesName = mod_id | ||
} | ||
|
||
minecraft { | ||
// The mappings can be changed at any time and must be in the following format. | ||
// Channel: Version: | ||
// snapshot YYYYMMDD Snapshot are built nightly. | ||
// stable # Stables are built at the discretion of the MCP team. | ||
// official MCVersion Official field/method names from Mojang mapping files | ||
// | ||
// You must be aware of the Mojang license when using the 'official' mappings. | ||
// See more information here: https://github.com/MinecraftForge/MCPConfig/blob/master/Mojang.md | ||
// | ||
// Use non-default mappings at your own risk. They may not always work. | ||
// Simply re-run your setup task after changing the mappings to update your workspace. | ||
mappings channel: 'official', version: '1.20.1' | ||
|
||
// accessTransformer = file('src/main/resources/META-INF/accesstransformer.cfg') | ||
|
||
// Default run configurations. | ||
// These can be tweaked, removed, or duplicated as needed. | ||
runs { | ||
client { | ||
workingDirectory project.file('run') | ||
|
||
// Recommended logging data for a userdev environment | ||
// The markers can be added/removed as needed separated by commas. | ||
// "SCAN": For mods scan. | ||
// "REGISTRIES": For firing of registry events. | ||
// "REGISTRYDUMP": For getting the contents of all registries. | ||
property 'forge.logging.markers', 'REGISTRIES' | ||
|
||
// Recommended logging level for the console | ||
// You can set various levels here. | ||
// Please read: https://stackoverflow.com/questions/2031163/when-to-use-the-different-log-levels | ||
property 'forge.logging.console.level', 'debug' | ||
|
||
mods { | ||
darkmodeeverywhere { | ||
source sourceSets.main | ||
} | ||
} | ||
} | ||
|
||
server { | ||
workingDirectory project.file('run') | ||
|
||
// Recommended logging data for a userdev environment | ||
// The markers can be added/removed as needed separated by commas. | ||
// "SCAN": For mods scan. | ||
// "REGISTRIES": For firing of registry events. | ||
// "REGISTRYDUMP": For getting the contents of all registries. | ||
property 'forge.logging.markers', 'REGISTRIES' | ||
|
||
// Recommended logging level for the console | ||
// You can set various levels here. | ||
// Please read: https://stackoverflow.com/questions/2031163/when-to-use-the-different-log-levels | ||
property 'forge.logging.console.level', 'debug' | ||
|
||
mods { | ||
darkmodeeverywhere { | ||
source sourceSets.main | ||
} | ||
} | ||
} | ||
// Mojang ships Java 21 to end users starting in 1.20.5, so mods should target Java 21. | ||
java.toolchain.languageVersion = JavaLanguageVersion.of(21) | ||
|
||
data { | ||
workingDirectory project.file('run') | ||
|
||
// Recommended logging data for a userdev environment | ||
// The markers can be added/removed as needed separated by commas. | ||
// "SCAN": For mods scan. | ||
// "REGISTRIES": For firing of registry events. | ||
// "REGISTRYDUMP": For getting the contents of all registries. | ||
property 'forge.logging.markers', 'REGISTRIES' | ||
|
||
// Recommended logging level for the console | ||
// You can set various levels here. | ||
// Please read: https://stackoverflow.com/questions/2031163/when-to-use-the-different-log-levels | ||
property 'forge.logging.console.level', 'debug' | ||
|
||
// Specify the modid for data generation, where to output the resulting resource, and where to look for existing resources. | ||
args '--mod', 'darkmodeeverywhere', '--all', '--output', file('src/generated/resources/'), '--existing', file('src/main/resources/') | ||
|
||
mods { | ||
darkmodeeverywhere { | ||
source sourceSets.main | ||
} | ||
} | ||
} | ||
//minecraft.accessTransformers.file rootProject.file('src/main/resources/META-INF/accesstransformer.cfg') | ||
//minecraft.accessTransformers.entry public net.minecraft.client.Minecraft textureManager # textureManager | ||
|
||
// Default run configurations. | ||
// These can be tweaked, removed, or duplicated as needed. | ||
runs { | ||
// applies to all the run configs below | ||
configureEach { | ||
// Recommended logging data for a userdev environment | ||
// The markers can be added/remove as needed separated by commas. | ||
// "SCAN": For mods scan. | ||
// "REGISTRIES": For firing of registry events. | ||
// "REGISTRYDUMP": For getting the contents of all registries. | ||
systemProperty 'forge.logging.markers', 'REGISTRIES' | ||
|
||
// Recommended logging level for the console | ||
// You can set various levels here. | ||
// Please read: https://stackoverflow.com/questions/2031163/when-to-use-the-different-log-levels | ||
systemProperty 'forge.logging.console.level', 'debug' | ||
|
||
modSource project.sourceSets.main | ||
} | ||
|
||
client { | ||
// Comma-separated list of namespaces to load gametests from. Empty = all namespaces. | ||
systemProperty 'forge.enabledGameTestNamespaces', project.mod_id | ||
} | ||
|
||
server { | ||
systemProperty 'forge.enabledGameTestNamespaces', project.mod_id | ||
programArgument '--nogui' | ||
} | ||
} | ||
|
||
mixin { | ||
add sourceSets.main, "darkmodeeverywhere.refmap.json" | ||
// This run config launches GameTestServer and runs all registered gametests, then exits. | ||
// By default, the server will crash when no gametests are provided. | ||
// The gametest system is also enabled by default for other run configs under the /test command. | ||
gameTestServer { | ||
systemProperty 'forge.enabledGameTestNamespaces', project.mod_id | ||
} | ||
|
||
data { | ||
// example of overriding the workingDirectory set in configureEach above, uncomment if you want to use it | ||
// workingDirectory project.file('run-data') | ||
|
||
config "darkmodeeverywhere.mixins.json" | ||
// Specify the modid for data generation, where to output the resulting resource, and where to look for existing resources. | ||
programArguments.addAll '--mod', project.mod_id, '--all', '--output', file('src/generated/resources/').getAbsolutePath(), '--existing', file('src/main/resources/').getAbsolutePath() | ||
} | ||
} | ||
|
||
// Include resources generated by data generators. | ||
sourceSets.main.resources { srcDir 'src/generated/resources' } | ||
|
||
repositories { | ||
// Put repositories for dependencies here | ||
// ForgeGradle automatically adds the Forge maven and Maven Central for you | ||
|
||
// If you have mod jar dependencies in ./libs, you can declare them as a repository like so: | ||
// flatDir { | ||
// dir 'libs' | ||
// } | ||
maven { | ||
// location of the maven that hosts JEI files | ||
name "Jared's maven" | ||
url "https://maven.blamejared.com" | ||
content { | ||
includeGroup "mezz.jei" | ||
} | ||
} | ||
maven { | ||
// CurseMaven | ||
name "cursemaven" | ||
url "https://cursemaven.com" | ||
content { | ||
includeGroup "curse.maven" | ||
} | ||
} | ||
// Sets up a dependency configuration called 'localRuntime'. | ||
// This configuration should be used instead of 'runtimeOnly' to declare | ||
// a dependency that will be present for runtime testing but that is | ||
// "optional", meaning it will not be pulled by dependents of this mod. | ||
configurations { | ||
runtimeClasspath.extendsFrom localRuntime | ||
} | ||
|
||
dependencies { | ||
// Specify the version of Minecraft to use. If this is any group other than 'net.minecraft' it is assumed | ||
// that the dep is a ForgeGradle 'patcher' dependency, and its patches will be applied. | ||
// The userdev artifact is a special name and will get all sorts of transformations applied to it. | ||
minecraft 'net.minecraftforge:forge:1.20.1-47.0.19' | ||
|
||
// compile against the JEI API but do not include it at runtime | ||
compileOnly fg.deobf("mezz.jei:jei-1.20.1-common-api:15.1.0.19") | ||
compileOnly fg.deobf("mezz.jei:jei-1.20.1-forge-api:15.1.0.19") | ||
// at runtime, use the full JEI jar for Forge | ||
runtimeOnly fg.deobf("mezz.jei:jei-1.20.1-forge:15.1.0.19") | ||
|
||
// Real mod deobf dependency examples - these get remapped to your current mappings | ||
// compileOnly fg.deobf("mezz.jei:jei-${mc_version}:${jei_version}:api") // Adds JEI API as a compile dependency | ||
// runtimeOnly fg.deobf("mezz.jei:jei-${mc_version}:${jei_version}") // Adds the full JEI mod as a runtime dependency | ||
// implementation fg.deobf("com.tterrag.registrate:Registrate:MC${mc_version}-${registrate_version}") // Adds registrate as a dependency | ||
|
||
// Examples using mod jars from ./libs | ||
// implementation fg.deobf("blank:coolmod-${mc_version}:${coolmod_version}") | ||
|
||
// For more info... | ||
// Specify the version of Minecraft to use. | ||
// Depending on the plugin applied there are several options. We will assume you applied the userdev plugin as shown above. | ||
// The group for userdev is net.neoforged, the module name is neoforge, and the version is the same as the neoforge version. | ||
// You can however also use the vanilla plugin (net.neoforged.gradle.vanilla) to use a version of Minecraft without the neoforge loader. | ||
// And its provides the option to then use net.minecraft as the group, and one of; client, server or joined as the module name, plus the game version as version. | ||
// For all intends and purposes: You can treat this dependency as if it is a normal library you would use. | ||
implementation "net.neoforged:neoforge:${neo_version}" | ||
|
||
// Example optional mod dependency with JEI | ||
// The JEI API is declared for compile time use, while the full JEI artifact is used at runtime | ||
// compileOnly "mezz.jei:jei-${mc_version}-common-api:${jei_version}" | ||
// compileOnly "mezz.jei:jei-${mc_version}-neoforge-api:${jei_version}" | ||
// We add the full version to localRuntime, not runtimeOnly, so that we do not publish a dependency on it | ||
// localRuntime "mezz.jei:jei-${mc_version}-neoforge:${jei_version}" | ||
|
||
// Example mod dependency using a mod jar from ./libs with a flat dir repository | ||
// This maps to ./libs/coolmod-${mc_version}-${coolmod_version}.jar | ||
// The group id is ignored when searching -- in this case, it is "blank" | ||
// implementation "blank:coolmod-${mc_version}:${coolmod_version}" | ||
|
||
// Example mod dependency using a file as dependency | ||
// implementation files("libs/coolmod-${mc_version}-${coolmod_version}.jar") | ||
|
||
// Example project dependency using a sister or child project: | ||
// implementation project(":myproject") | ||
|
||
// For more info: | ||
// http://www.gradle.org/docs/current/userguide/artifact_dependencies_tutorial.html | ||
// http://www.gradle.org/docs/current/userguide/dependency_management.html | ||
} | ||
|
||
annotationProcessor 'org.spongepowered:mixin:0.8.5:processor' | ||
// This block of code expands all declared replace properties in the specified resource targets. | ||
// A missing property will result in an error. Properties are expanded using ${} Groovy notation. | ||
// When "copyIdeResources" is enabled, this will also run before the game launches in IDE environments. | ||
// See https://docs.gradle.org/current/dsl/org.gradle.language.jvm.tasks.ProcessResources.html | ||
tasks.withType(ProcessResources).configureEach { | ||
var replaceProperties = [ | ||
minecraft_version : minecraft_version, | ||
minecraft_version_range: minecraft_version_range, | ||
neo_version : neo_version, | ||
neo_version_range : neo_version_range, | ||
loader_version_range : loader_version_range, | ||
mod_id : mod_id, | ||
mod_name : mod_name, | ||
mod_license : mod_license, | ||
mod_version : mod_version, | ||
mod_authors : mod_authors, | ||
mod_description : mod_description | ||
] | ||
inputs.properties replaceProperties | ||
|
||
filesMatching(['META-INF/neoforge.mods.toml']) { | ||
expand replaceProperties | ||
} | ||
} | ||
|
||
// Example for how to get properties into the manifest for reading at runtime. | ||
jar { | ||
manifest { | ||
attributes([ | ||
"Specification-Title" : "darkmodeeverywhere", | ||
"Specification-Vendor" : "Buuz135", | ||
"Specification-Version" : "1", // We are version 1 of ourselves | ||
"Implementation-Title" : project.name, | ||
"Implementation-Version" : project.jar.archiveVersion, | ||
"Implementation-Vendor" : "Buuz135", | ||
"Implementation-Timestamp": new Date().format("yyyy-MM-dd'T'HH:mm:ssZ") | ||
]) | ||
// Example configuration to allow publishing using the maven-publish plugin | ||
publishing { | ||
publications { | ||
register('mavenJava', MavenPublication) { | ||
from components.java | ||
} | ||
} | ||
repositories { | ||
maven { | ||
url "file://${project.projectDir}/repo" | ||
} | ||
} | ||
} | ||
|
||
jar.finalizedBy('reobfJar') | ||
tasks.withType(JavaCompile).configureEach { | ||
options.encoding = 'UTF-8' // Use the UTF-8 charset for Java compilation | ||
} | ||
|
||
// IDEA no longer automatically downloads sources/javadoc jars for dependencies, so we need to explicitly enable the behavior. | ||
idea { | ||
module { | ||
downloadSources = true | ||
downloadJavadoc = true | ||
} | ||
} |
Oops, something went wrong.