-
Notifications
You must be signed in to change notification settings - Fork 2
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
1 parent
ec65fa5
commit 2def6ee
Showing
190 changed files
with
1,248 additions
and
1,564 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 |
---|---|---|
@@ -1,5 +1,9 @@ | ||
# Disable autocrlf on generated files, they always generate with LF | ||
# Add any extra files or paths here to make git stop saying they | ||
# are changed when only line endings change. | ||
src/generated/**/.cache/cache text eol=lf | ||
src/generated/**/*.json text eol=lf | ||
# | ||
# https://help.github.com/articles/dealing-with-line-endings/ | ||
# | ||
# Linux start script should use lf | ||
/gradlew text eol=lf | ||
|
||
# These are Windows script files and should use crlf | ||
*.bat text eol=crlf | ||
|
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,26 +1,40 @@ | ||
# gradle | ||
|
||
.gradle/ | ||
build/ | ||
out/ | ||
classes/ | ||
|
||
# eclipse | ||
bin | ||
|
||
*.launch | ||
.settings | ||
.metadata | ||
.classpath | ||
.project | ||
|
||
# idea | ||
out | ||
|
||
.idea/ | ||
*.iml | ||
*.ipr | ||
*.iws | ||
*.iml | ||
.idea | ||
|
||
# gradle | ||
build | ||
.gradle | ||
# vscode | ||
|
||
.settings/ | ||
.vscode/ | ||
bin/ | ||
.classpath | ||
.project | ||
|
||
# macos | ||
|
||
*.DS_Store | ||
|
||
# fabric | ||
|
||
run/ | ||
|
||
# other | ||
eclipse | ||
run | ||
runs | ||
run-data | ||
# java | ||
|
||
repo | ||
hs_err_*.log | ||
replay_*.log | ||
*.hprof | ||
*.jfr |
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,230 +1,116 @@ | ||
plugins { | ||
id 'java-library' | ||
id 'maven-publish' | ||
id 'net.neoforged.moddev' version '2.0.75' | ||
id 'idea' | ||
id 'fabric-loom' version '1.7-SNAPSHOT' | ||
id 'maven-publish' | ||
} | ||
|
||
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 | ||
} | ||
|
||
version = "${mod_version}+neoforged-${minecraft_version}" | ||
group = mod_group_id | ||
|
||
repositories { | ||
mavenLocal() | ||
|
||
maven { url 'https://maven.wispforest.io/releases' } | ||
maven { url 'https://maven.su5ed.dev/releases' } | ||
maven { url 'https://maven.fabricmc.net' } | ||
maven { url 'https://maven.shedaniel.me/' } | ||
maven { | ||
name = "Su5eD" | ||
url = "https://maven.su5ed.dev/releases" | ||
content { | ||
// Forgified Fabric API - Required by Accessories | ||
includeGroup "org.sinytra.forgified-fabric-api" | ||
} | ||
} | ||
|
||
maven { | ||
name = 'TerraformersMC' | ||
url = 'https://maven.terraformersmc.com/' | ||
} | ||
|
||
maven { | ||
name = 'BlameJared Maven (CrT / Bookshelf)' | ||
url = 'https://maven.blamejared.com' | ||
} | ||
} | ||
version = "${mod_version}+fabric-${minecraft_version}" | ||
group = project.maven_group | ||
|
||
base { | ||
archivesName = mod_id | ||
archivesName = project.archives_base_name | ||
} | ||
|
||
// Mojang ships Java 21 to end users starting in 1.20.5, so mods should target Java 21. | ||
java.toolchain.languageVersion = JavaLanguageVersion.of(21) | ||
|
||
neoForge { | ||
// Specify the version of NeoForge to use. | ||
version = project.neo_version | ||
|
||
parchment { | ||
mappingsVersion = project.parchment_mappings_version | ||
minecraftVersion = project.parchment_minecraft_version | ||
} | ||
|
||
// This line is optional. Access Transformers are automatically detected | ||
// accessTransformers = project.files('src/main/resources/META-INF/accesstransformer.cfg') | ||
|
||
// Default run configurations. | ||
// These can be tweaked, removed, or duplicated as needed. | ||
runs { | ||
client { | ||
client() | ||
|
||
// Comma-separated list of namespaces to load gametests from. Empty = all namespaces. | ||
systemProperty 'neoforge.enabledGameTestNamespaces', project.mod_id | ||
} | ||
|
||
server { | ||
server() | ||
programArgument '--nogui' | ||
systemProperty 'neoforge.enabledGameTestNamespaces', project.mod_id | ||
} | ||
|
||
// 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 { | ||
type = "gameTestServer" | ||
systemProperty 'neoforge.enabledGameTestNamespaces', project.mod_id | ||
} | ||
|
||
data { | ||
data() | ||
|
||
// example of overriding the workingDirectory set in configureEach above, uncomment if you want to use it | ||
// gameDirectory = project.file('run-data') | ||
|
||
// 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() | ||
} | ||
|
||
// applies to all the run configs above | ||
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 | ||
logLevel = org.slf4j.event.Level.DEBUG | ||
} | ||
} | ||
|
||
mods { | ||
// define mod <-> source bindings | ||
// these are used to tell the game which sources are for which mod | ||
// multi mod projects should define one per mod | ||
"${mod_id}" { | ||
sourceSet(sourceSets.main) | ||
} | ||
} | ||
repositories { | ||
// Add repositories to retrieve artifacts from in here. | ||
// You should only use this when depending on other mods because | ||
// Loom adds the essential maven repositories to download Minecraft and libraries from automatically. | ||
// See https://docs.gradle.org/current/userguide/declaring_repositories.html | ||
// for more information about repositories. | ||
|
||
maven { url 'https://maven.wispforest.io/releases' } | ||
maven { url 'https://maven.su5ed.dev/releases' } | ||
maven { url 'https://maven.fabricmc.net' } | ||
maven { url 'https://maven.shedaniel.me/' } | ||
|
||
maven { | ||
name = 'TerraformersMC' | ||
url = 'https://maven.terraformersmc.com/' | ||
} | ||
|
||
maven { | ||
name = 'BlameJared Maven (CrT / Bookshelf)' | ||
url = 'https://maven.blamejared.com' | ||
} | ||
} | ||
|
||
// Include resources generated by data generators. | ||
sourceSets.main.resources { srcDir 'src/generated/resources' } | ||
fabricApi { | ||
configureDataGeneration() | ||
} | ||
|
||
// 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 | ||
loom { | ||
accessWidenerPath = file("src/main/resources/hibernalherbs.accesswidener") | ||
} | ||
|
||
dependencies { | ||
// 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}" | ||
// To change the versions see the gradle.properties file | ||
minecraft "com.mojang:minecraft:${minecraft_version}" | ||
mappings loom.officialMojangMappings() | ||
modImplementation "net.fabricmc:fabric-loader:${loader_version}" | ||
|
||
// Example mod dependency using a file as dependency | ||
// implementation files("libs/coolmod-${mc_version}-${coolmod_version}.jar") | ||
// Fabric API. This is technically optional, but you probably want it anyway. | ||
modImplementation "net.fabricmc.fabric-api:fabric-api:${fabric_version}" | ||
|
||
// Example project dependency using a sister or child project: | ||
// implementation project(":myproject") | ||
// EMI | ||
//modCompileOnly "dev.emi:emi-fabric:${emi_version}+${minecraft_version}:api" | ||
modImplementation "dev.emi:emi-fabric:${emi_version}+${minecraft_version}" | ||
|
||
// For more info: | ||
// http://www.gradle.org/docs/current/userguide/artifact_dependencies_tutorial.html | ||
// http://www.gradle.org/docs/current/userguide/dependency_management.html | ||
// Terraform API | ||
//modImplementation "com.terraformersmc.terraform-api:terraform-wood-api-v1:11.0.0-alpha.1" | ||
//include "com.terraformersmc.terraform-api:terraform-wood-api-v1:11.0.0-alpha.1" | ||
|
||
// Trinkets | ||
//modImplementation("dev.emi:trinkets:${trinkets_version}") | ||
|
||
// EMI | ||
//modCompileOnly "dev.emi:emi-fabric:${emi_version}+${minecraft_version}:api" | ||
implementation "dev.emi:emi-neoforge:${emi_version}+${minecraft_version}" | ||
// Moving over to Accessories - recommended to utilise the Trinkets Compatibility Layer | ||
modImplementation("io.wispforest:accessories-fabric:${accessories_version}+${minecraft_version}") | ||
|
||
// Terraform API | ||
//modImplementation "com.terraformersmc.terraform-api:terraform-wood-api-v1:11.0.0-alpha.1" | ||
//include "com.terraformersmc.terraform-api:terraform-wood-api-v1:11.0.0-alpha.1" | ||
|
||
// Trinkets | ||
//modImplementation("dev.emi:trinkets:${trinkets_version}") | ||
// Patchouli | ||
modImplementation "vazkii.patchouli:Patchouli:${patchouli_version}-FABRIC-SNAPSHOT" | ||
|
||
} | ||
|
||
// Moving over to Accessories - recommended to utilise the Trinkets Compatibility Layer | ||
implementation "io.wispforest:accessories-neoforge:${accessories_version}+${minecraft_version}" | ||
processResources { | ||
inputs.property "version", project.version | ||
|
||
// Patchouli | ||
implementation "vazkii.patchouli:Patchouli:${patchouli_version}-NEOFORGE" | ||
filesMatching("fabric.mod.json") { | ||
expand "version": project.version | ||
} | ||
} | ||
|
||
// 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. | ||
var generateModMetadata = tasks.register("generateModMetadata", ProcessResources) { | ||
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 | ||
expand replaceProperties | ||
from "src/main/templates" | ||
into "build/generated/sources/modMetadata" | ||
tasks.withType(JavaCompile).configureEach { | ||
it.options.release = 21 | ||
} | ||
// Include the output of "generateModMetadata" as an input directory for the build | ||
// this works with both building through Gradle and the IDE. | ||
sourceSets.main.resources.srcDir generateModMetadata | ||
// To avoid having to run "generateModMetadata" manually, make it run on every project reload | ||
neoForge.ideSyncTask generateModMetadata | ||
|
||
// 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" | ||
} | ||
} | ||
} | ||
java { | ||
// Loom will automatically attach sourcesJar to a RemapSourcesJar task and to the "build" task | ||
// if it is present. | ||
// If you remove this line, sources will not be generated. | ||
withSourcesJar() | ||
|
||
tasks.withType(JavaCompile).configureEach { | ||
options.encoding = 'UTF-8' // Use the UTF-8 charset for Java compilation | ||
sourceCompatibility = JavaVersion.VERSION_21 | ||
targetCompatibility = JavaVersion.VERSION_21 | ||
} | ||
|
||
// IDEA no longer automatically downloads sources/javadoc jars for dependencies, so we need to explicitly enable the behavior. | ||
idea { | ||
module { | ||
downloadSources = true | ||
downloadJavadoc = true | ||
} | ||
jar { | ||
from("LICENSE") { | ||
rename { "${it}_${project.base.archivesName.get()}"} | ||
} | ||
} | ||
|
||
// configure the maven publication | ||
publishing { | ||
publications { | ||
create("mavenJava", MavenPublication) { | ||
artifactId = project.archives_base_name | ||
from components.java | ||
} | ||
} | ||
|
||
// See https://docs.gradle.org/current/userguide/publishing_maven.html for information on how to set up publishing. | ||
repositories { | ||
// Add repositories to publish to here. | ||
// Notice: This block does NOT have the same function as the block in the top level. | ||
// The repositories here will be used for publishing your artifact, not for | ||
// retrieving dependencies. | ||
} | ||
} |
Oops, something went wrong.