Create/build.gradle

233 lines
7.6 KiB
Groovy
Raw Normal View History

buildscript {
repositories {
maven { url = 'https://maven.minecraftforge.net' }
mavenCentral()
jcenter()
maven { url = 'https://repo.spongepowered.org/repository/maven-public/' }
}
dependencies {
classpath group: 'net.minecraftforge.gradle', name: 'ForgeGradle', version: "${forgegradle_version}", changing: true
classpath group: 'org.spongepowered', name: 'mixingradle', version: "${mixingradle_version}"
}
}
plugins {
id 'com.github.johnrengelman.shadow' version "${shadow_version}"
id 'com.matthewprenger.cursegradle' version "${cursegradle_version}"
}
apply plugin: 'net.minecraftforge.gradle'
// Only edit below this line, the above code adds and enables the necessary things for Forge to be setup.
apply plugin: 'eclipse'
apply plugin: 'maven-publish'
apply plugin: 'org.spongepowered.mixin'
boolean dev = System.getenv('RELEASE') == null || System.getenv('RELEASE').equals('false');
ext.buildnumber = 0
project.buildnumber = System.getenv('BUILD_NUMBER') != null ? System.getenv('BUILD_NUMBER') : "custom"
version = "mc${minecraft_version}_v${mod_version}" + (dev ? "+${buildnumber}" : '')
group = 'com.simibubi.create'
archivesBaseName = 'create'
sourceCompatibility = targetCompatibility = compileJava.sourceCompatibility = compileJava.targetCompatibility = '1.8'
minecraft {
Merge remote-tracking branch 'origin/mc1.15/dev' into mc1.16/dev Update to 1.16.3 Conflicts: src/main/java/com/simibubi/create/AllBlockPartials.java src/main/java/com/simibubi/create/AllBlocks.java src/main/java/com/simibubi/create/AllTags.java src/main/java/com/simibubi/create/ClientEvents.java src/main/java/com/simibubi/create/CommonEvents.java src/main/java/com/simibubi/create/content/contraptions/components/actors/StorageInterfaceMovement.java src/main/java/com/simibubi/create/content/contraptions/components/crafter/MechanicalCrafterTileEntity.java src/main/java/com/simibubi/create/content/contraptions/components/deployer/DeployerTileEntity.java src/main/java/com/simibubi/create/content/contraptions/components/fan/AirCurrent.java src/main/java/com/simibubi/create/content/contraptions/components/fan/NozzleTileEntity.java src/main/java/com/simibubi/create/content/contraptions/components/mixer/MechanicalMixerTileEntity.java src/main/java/com/simibubi/create/content/contraptions/components/structureMovement/Contraption.java src/main/java/com/simibubi/create/content/contraptions/components/structureMovement/ContraptionCollider.java src/main/java/com/simibubi/create/content/contraptions/components/structureMovement/ContraptionEntity.java src/main/java/com/simibubi/create/content/contraptions/components/structureMovement/glue/SuperGlueItem.java src/main/java/com/simibubi/create/content/contraptions/components/structureMovement/glue/SuperGlueRenderer.java src/main/java/com/simibubi/create/content/contraptions/components/structureMovement/mounted/CartAssemblerBlock.java src/main/java/com/simibubi/create/content/contraptions/fluids/FluidPipeBlock.java src/main/java/com/simibubi/create/content/contraptions/fluids/FluidPipeModel.java src/main/java/com/simibubi/create/content/contraptions/fluids/FluidTankBlock.java src/main/java/com/simibubi/create/content/contraptions/fluids/FluidTankCTBehaviour.java src/main/java/com/simibubi/create/content/contraptions/fluids/FluidTankModel.java src/main/java/com/simibubi/create/content/contraptions/fluids/PumpBlock.java src/main/java/com/simibubi/create/content/contraptions/particle/AirFlowParticle.java src/main/java/com/simibubi/create/content/contraptions/processing/HeaterBlock.java src/main/java/com/simibubi/create/content/contraptions/processing/HeaterRenderer.java src/main/java/com/simibubi/create/content/contraptions/processing/HeaterTileEntity.java src/main/java/com/simibubi/create/content/contraptions/relays/belt/BeltHelper.java src/main/java/com/simibubi/create/content/curiosities/ChromaticCompoundItem.java src/main/java/com/simibubi/create/content/curiosities/symmetry/SymmetryWandScreen.java src/main/java/com/simibubi/create/content/curiosities/tools/SandPaperPolishingRecipe.java src/main/java/com/simibubi/create/content/logistics/block/extractor/ExtractorBlock.java src/main/java/com/simibubi/create/content/logistics/block/extractor/ExtractorMovementBehaviour.java src/main/java/com/simibubi/create/content/logistics/block/extractor/ExtractorSlots.java src/main/java/com/simibubi/create/content/logistics/block/extractor/ExtractorTileEntity.java src/main/java/com/simibubi/create/content/logistics/block/extractor/LinkedExtractorBlock.java src/main/java/com/simibubi/create/content/logistics/block/funnel/FunnelFilterSlotPositioning.java src/main/java/com/simibubi/create/foundation/fluid/FluidRenderer.java src/main/java/com/simibubi/create/foundation/tileEntity/behaviour/belt/TransportedItemStackHandlerBehaviour.java src/main/java/com/simibubi/create/foundation/tileEntity/behaviour/inventory/SynchronizedExtraction.java src/main/java/com/simibubi/create/foundation/utility/AngleHelper.java src/main/java/com/simibubi/create/foundation/utility/BlockHelper.java src/main/java/com/simibubi/create/foundation/utility/VecHelper.java src/main/java/com/simibubi/create/foundation/utility/outliner/BlockClusterOutline.java src/main/java/com/simibubi/create/foundation/utility/outliner/Outline.java
2020-09-20 00:37:27 -04:00
mappings channel: 'snapshot', version: '20200920-mixed-1.16.3'
accessTransformer = file('src/main/resources/META-INF/accesstransformer.cfg')
2021-04-09 16:23:49 -07:00
runs {
client {
workingDirectory project.file('run')
2021-01-12 21:58:40 -08:00
arg '-mixin.config=create.mixins.json'
2021-04-09 16:23:49 -07:00
//jvmArgs '-XX:+UnlockCommercialFeatures' // uncomment for profiling
property 'forge.logging.console.level', 'info'
property 'fml.earlyprogresswindow', 'false'
2021-06-19 00:29:18 -07:00
property 'mixin.env.disableRefMap', 'true'
mods {
create {
source sourceSets.main
}
}
}
server {
workingDirectory project.file('run/server')
2021-01-12 21:58:40 -08:00
arg '-mixin.config=create.mixins.json'
property 'forge.logging.console.level', 'info'
mods {
create {
source sourceSets.main
}
}
}
data {
workingDirectory project.file('run')
property 'forge.logging.markers', 'REGISTRIES,REGISTRYDUMP'
property 'forge.logging.console.level', 'debug'
property 'fml.earlyprogresswindow', 'false'
args '--mod', 'create', '--all', '--output', file('src/generated/resources/'), '--existing', file('src/main/resources')
mods {
create {
source sourceSets.main
}
}
}
}
}
compileJava {
options.compilerArgs = ["-Xdiags:verbose"]
}
sourceSets.main.resources {
srcDir 'src/generated/resources'
}
Merge remote-tracking branch 'origin/mc1.16/dev' into mc1.16/chromatic-projector # Conflicts: # src/generated/resources/assets/create/lang/en_us.json # src/generated/resources/assets/create/lang/unfinished/de_de.json # src/generated/resources/assets/create/lang/unfinished/es_es.json # src/generated/resources/assets/create/lang/unfinished/es_mx.json # src/generated/resources/assets/create/lang/unfinished/fr_fr.json # src/generated/resources/assets/create/lang/unfinished/it_it.json # src/generated/resources/assets/create/lang/unfinished/ja_jp.json # src/generated/resources/assets/create/lang/unfinished/ko_kr.json # src/generated/resources/assets/create/lang/unfinished/nl_nl.json # src/generated/resources/assets/create/lang/unfinished/pl_pl.json # src/generated/resources/assets/create/lang/unfinished/pt_br.json # src/generated/resources/assets/create/lang/unfinished/ru_ru.json # src/generated/resources/assets/create/lang/unfinished/zh_cn.json # src/generated/resources/assets/create/lang/unfinished/zh_tw.json # src/main/java/com/simibubi/create/AllContainerTypes.java # src/main/java/com/simibubi/create/content/contraptions/base/KineticTileEntity.java # src/main/java/com/simibubi/create/content/contraptions/components/deployer/DeployerHandler.java # src/main/java/com/simibubi/create/content/contraptions/components/structureMovement/mounted/CartAssemblerTileEntity.java # src/main/java/com/simibubi/create/content/curiosities/tools/BlueprintEntity.java # src/main/java/com/simibubi/create/content/curiosities/tools/BlueprintOverlayRenderer.java # src/main/java/com/simibubi/create/content/curiosities/tools/BlueprintRenderer.java # src/main/java/com/simibubi/create/content/curiosities/tools/BlueprintScreen.java # src/main/java/com/simibubi/create/content/logistics/block/mechanicalArm/ArmRenderer.java # src/main/java/com/simibubi/create/content/logistics/item/LinkedControllerScreen.java # src/main/java/com/simibubi/create/content/logistics/item/filter/AttributeFilterScreen.java # src/main/java/com/simibubi/create/content/logistics/item/filter/FilterContainer.java # src/main/java/com/simibubi/create/content/schematics/block/SchematicTableScreen.java # src/main/java/com/simibubi/create/content/schematics/block/SchematicannonTileEntity.java # src/main/java/com/simibubi/create/foundation/gui/AllGuiTextures.java # src/main/java/com/simibubi/create/foundation/gui/mainMenu/CreateMainMenuScreen.java # src/main/java/com/simibubi/create/foundation/ponder/content/ChainDriveScenes.java # src/main/java/com/simibubi/create/foundation/render/SuperByteBuffer.java # src/main/resources/META-INF/mods.toml # src/main/resources/assets/create/lang/default/messages.json # src/main/resources/assets/create/lang/default/tooltips.json
2021-06-19 00:54:43 -07:00
mixin {
add sourceSets.main, "create.refmap.json"
}
repositories {
maven {
// Location of the maven that hosts JEI files (and TiC)
name = "Progwml6 maven"
url = "https://dvs1.progwml6.com/files/maven/"
}
/*maven {
// Location of a maven mirror for JEI files, as a fallback
name = "ModMaven"
url = "https://modmaven.k-4u.nl"
}*/
maven {
// Location of the maven for vazkii's mods
name = "blamejared"
url = "http://maven.blamejared.com/"
}
maven {
// Location of the maven for mixed mappings, Registrate, and Flywheel
name = "tterrag maven"
url = "https://maven.tterrag.com/"
}
2021-01-20 22:36:04 +01:00
maven {
url = "https://www.cursemaven.com"
2021-06-19 00:29:18 -07:00
content {
includeGroup "curse.maven"
}
2021-01-20 22:36:04 +01:00
}
}
configurations {
shade
}
dependencies {
minecraft "net.minecraftforge:forge:${minecraft_version}-${forge_version}"
2021-04-09 16:23:49 -07:00
def registrate = "com.tterrag.registrate:Registrate:MC1.16.5-${registrate_version}"
implementation fg.deobf(registrate)
shade registrate
2021-06-22 21:09:32 -07:00
if (findProject(':Flywheel') != null) {
implementation project(':Flywheel') // jozu: I use a gradle workspace with both projects
2021-06-22 21:09:32 -07:00
} else {
implementation fg.deobf("com.jozufozu.flywheel:Flywheel:${flywheel_version}")
2021-06-22 21:09:32 -07:00
}
2021-06-19 00:29:18 -07:00
// Compile against the JEI API but do not include it at runtime
compileOnly fg.deobf("mezz.jei:jei-1.16.5:${jei_version}:api")
// At runtime, use the full JEI jar
runtimeOnly fg.deobf("mezz.jei:jei-1.16.5:${jei_version}")
2021-01-20 22:36:04 +01:00
// implementation fg.deobf("curse.maven:druidcraft-340991:3101903")
// i'll leave this here commented for easier testing
//runtimeOnly fg.deobf("vazkii.arl:AutoRegLib:1.4-35.69")
//runtimeOnly fg.deobf("vazkii.quark:Quark:r2.0-212.984")
//runtimeOnly fg.deobf("slimeknights.mantle:Mantle:1.16.5-1.6.103")
//runtimeOnly fg.deobf("slimeknights.tconstruct:TConstruct:1.16.5-3.0.3.168")
2021-01-13 09:50:00 +01:00
annotationProcessor 'org.spongepowered:mixin:0.8.2:processor'
}
jar {
2020-06-09 19:34:57 -04:00
classifier = 'slim'
manifest {
attributes([
"Specification-Title": "create",
"Specification-Vendor": "simibubi",
"Specification-Version": "1",
"Implementation-Title": project.name,
"Implementation-Version": "${version}",
"Implementation-Vendor" :"simibubi",
2021-01-12 21:58:40 -08:00
"Implementation-Timestamp": new Date().format("yyyy-MM-dd'T'HH:mm:ssZ"),
"MixinConfigs": "create.mixins.json"
])
}
}
shadowJar {
2020-06-09 19:34:57 -04:00
classifier = ''
configurations = [project.configurations.shade]
relocate 'com.tterrag.registrate', 'com.simibubi.create.repack.registrate'
}
reobf {
shadowJar {}
}
String getChangelogText() {
def changelogFile = file('changelog.txt')
String str = ''
int lineCount = 0
boolean done = false
changelogFile.eachLine {
if (done || it == null) {
return
}
if (it.size() > 1) {
def temp = it
if (lineCount == 0) {
temp = "Create ${version}"
temp = "<span style=\"font-size: 18px; color: #333399;\">Create v${mod_version}</span>&nbsp;&nbsp;<em>for Minecraft ${minecraft_version}</em><br/>"
} else if (it.startsWith('-')) {
temp = "&nbsp;&nbsp;&nbsp;$temp<br/>"
temp = temp.replaceAll("(\\S+\\/\\S+)#([0-9]+)\\b", "<a href=\"https://github.com/\$1/issues/\$2\">\$0</a>");
temp = temp.replaceAll("#([0-9]+)\\b(?!<\\/a>)", "<a href=\"https://github.com/$github_project/issues/\$1\">\$0</a>");
} else {
temp = "<h4>$temp</h4>"
}
str += temp
lineCount++
} else {
str += "<p>Please submit any Issues you come across on the&nbsp;<a href=\"https://github.com/${github_project}/issues\" rel=\"nofollow\">Issue Tracker</a>.</p>"
done = true
}
}
return str
}
2020-06-09 19:45:38 -04:00
//changelog debugging
//new File("changelog.html").write getChangelogText()
tasks.curseforge.enabled = !dev && project.hasProperty('simi_curseforge_key')
2021-04-09 16:23:49 -07:00
curseforge {
if (project.hasProperty('simi_curseforge_key')) {
apiKey = project.simi_curseforge_key
}
project {
id = project.projectId
changelog = System.getenv('CHANGELOG') == null || System.getenv('CHANGELOG').equals('none') ? getChangelogText() : System.getenv('CHANGELOG')
changelogType = 'html'
releaseType = project.curse_type
mainArtifact(shadowJar) {
displayName = "Create - ${version}"
}
relations {
optionalDependency 'jei'
}
}
}