Fix gradle builds

This commit is contained in:
libraryaddict 2024-11-12 19:37:25 +13:00
parent cc47d6cdb4
commit 5abc9b8fc1
4 changed files with 58 additions and 19 deletions

View File

@ -11,23 +11,23 @@ ext {
remapServerCode = true remapServerCode = true
} }
afterEvaluate { dependencies {
dependencies { implementation project(':shared')
implementation project(':shared') compileOnly libs.io.netty.netty.buffer
compileOnly libs.io.netty.netty.buffer compileOnly libs.it.unimi.dsi.fastutil
compileOnly libs.it.unimi.dsi.fastutil compileOnly libs.com.mojang.datafixerupper
compileOnly libs.com.mojang.datafixerupper
afterEvaluate {
if (remapServerCode) { if (remapServerCode) {
implementation "org.spigotmc:spigot:${craftbukkitVersion}:remapped-mojang" implementation "org.spigotmc:spigot:${craftbukkitVersion}:remapped-mojang"
implementation "org.spigotmc:spigot:${craftbukkitVersion}:remapped-obf"
implementation "org.spigotmc:minecraft-server:${craftbukkitVersion}:maps-mojang@txt"
implementation "org.spigotmc:minecraft-server:${craftbukkitVersion}:maps-spigot@csrg"
} else { } else {
implementation "org.spigotmc:spigot:${craftbukkitVersion}" implementation "org.spigotmc:spigot:${craftbukkitVersion}"
} }
} }
configurations.all {
resolutionStrategy.force "org.spigotmc:spigot:${craftbukkitVersion}:remapped-mojang"
}
} }
afterEvaluate { afterEvaluate {

View File

@ -14,11 +14,23 @@ buildscript {
// Spigot server code remapping: https://www.spigotmc.org/threads/spigot-bungeecord-1-17-1-17-1.510208/ // Spigot server code remapping: https://www.spigotmc.org/threads/spigot-bungeecord-1-17-1-17-1.510208/
// These dependencies and mappings are installed into the local Maven repository when BuildTools builds the Spigot dependencies. // These dependencies and mappings are installed into the local Maven repository when BuildTools builds the Spigot dependencies.
def m2Repo = new File(repositories.mavenLocal().url.path) def gradleCache = new File(System.getProperty("user.home"), '.gradle/caches/modules-2/files-2.1')
def remappedMojang = new File(m2Repo, 'org/spigotmc/spigot/{craftbukkitVersion}/spigot-{craftbukkitVersion}-remapped-mojang.jar').path def findInGradleCache = { group, module, version, fileName ->
def remappedObf = new File(m2Repo, 'org/spigotmc/spigot/{craftbukkitVersion}/spigot-{craftbukkitVersion}-remapped-obf.jar').path def baseDir = new File(gradleCache, "${group}/${module}/${version}")
def mojangMappings = new File(m2Repo, 'org/spigotmc/minecraft-server/{craftbukkitVersion}/minecraft-server-{craftbukkitVersion}-maps-mojang.txt').path
def spigotMappings = new File(m2Repo, 'org/spigotmc/minecraft-server/{craftbukkitVersion}/minecraft-server-{craftbukkitVersion}-maps-spigot.csrg').path if (!baseDir.exists()) {
throw new Exception("Failed to resolve ${baseDir} when trying to load ${fileName}. Cache missing");
}
def result = baseDir.listFiles()?.findAll { it.isDirectory() }?.collectMany({ it.listFiles().flatten() })?.find { it.name == fileName }?.path
if (result == null) {
throw new Exception("Failed to resolve ${baseDir}/<cache key>/${fileName}");
}
return result;
}
def specialSource = buildscript.configurations.specialSource.resolvedConfiguration.getFirstLevelModuleDependencies().find { def specialSource = buildscript.configurations.specialSource.resolvedConfiguration.getFirstLevelModuleDependencies().find {
it.moduleGroup == 'net.md-5' && it.moduleName == 'SpecialSource' it.moduleGroup == 'net.md-5' && it.moduleName == 'SpecialSource'
@ -26,6 +38,9 @@ def specialSource = buildscript.configurations.specialSource.resolvedConfigurati
// Converts from Mojang's mappings to Minecraft's obfuscated mappings. // Converts from Mojang's mappings to Minecraft's obfuscated mappings.
ext.remapMojangToObfuscated = { inputFile, outputFile, craftbukkitVersion -> ext.remapMojangToObfuscated = { inputFile, outputFile, craftbukkitVersion ->
def remappedMojang = findInGradleCache("org.spigotmc", "spigot", craftbukkitVersion, "spigot-${craftbukkitVersion}-remapped-mojang.jar")
def mojangMappings = findInGradleCache("org.spigotmc", "minecraft-server", craftbukkitVersion, "minecraft-server-${craftbukkitVersion}-maps-mojang.txt")
println '> remapMojangToObfuscated' println '> remapMojangToObfuscated'
println ' Input: ' + inputFile.path println ' Input: ' + inputFile.path
println ' Output: ' + outputFile.path println ' Output: ' + outputFile.path
@ -38,13 +53,16 @@ ext.remapMojangToObfuscated = { inputFile, outputFile, craftbukkitVersion ->
'--live', '--live',
'-i', inputFile.path, '-i', inputFile.path,
'-o', outputFile.path, '-o', outputFile.path,
'-m', mojangMappings.replace('{craftbukkitVersion}', craftbukkitVersion), '-m', mojangMappings,
'--reverse' '--reverse'
} }
} }
// Converts from Minecraft's obfuscated mappings to Spigot's mappings. // Converts from Minecraft's obfuscated mappings to Spigot's mappings.
ext.remapObfuscatedToSpigot = { inputFile, outputFile, craftbukkitVersion -> ext.remapObfuscatedToSpigot = { inputFile, outputFile, craftbukkitVersion ->
def spigotMappings = findInGradleCache("org.spigotmc", "minecraft-server", craftbukkitVersion, "minecraft-server-${craftbukkitVersion}-maps-spigot.csrg")
def remappedObf = findInGradleCache("org.spigotmc", "spigot", craftbukkitVersion, "spigot-${craftbukkitVersion}-remapped-obf.jar")
println '> remapObfuscatedToSpigot' println '> remapObfuscatedToSpigot'
println ' Input: ' + inputFile.path println ' Input: ' + inputFile.path
println ' Output: ' + outputFile.path println ' Output: ' + outputFile.path
@ -57,7 +75,7 @@ ext.remapObfuscatedToSpigot = { inputFile, outputFile, craftbukkitVersion ->
'--live', '--live',
'-i', inputFile.path, '-i', inputFile.path,
'-o', outputFile.path, '-o', outputFile.path,
'-m', spigotMappings.replace('{craftbukkitVersion}', craftbukkitVersion) '-m', spigotMappings
} }
} }

View File

@ -208,9 +208,9 @@ public enum DisguiseType {
PAINTING, PAINTING,
@NmsAddedIn(NmsVersion.v1_21_R2) PALE_OAK_BOAT, @NmsAddedIn(NmsVersion.UNSUPPORTED) PALE_OAK_BOAT,
@NmsAddedIn(NmsVersion.v1_21_R2) PALE_OAK_CHEST_BOAT, @NmsAddedIn(NmsVersion.UNSUPPORTED) PALE_OAK_CHEST_BOAT,
@NmsAddedIn(NmsVersion.v1_14) PANDA, @NmsAddedIn(NmsVersion.v1_14) PANDA,

View File

@ -2145,6 +2145,27 @@ public class ReflectionManager {
if (nmsEntityName == null) { if (nmsEntityName == null) {
switch (disguiseType) { switch (disguiseType) {
case BOAT:
case ACACIA_BOAT:
case BIRCH_BOAT:
case CHERRY_BOAT:
case DARK_OAK_BOAT:
case JUNGLE_BOAT:
case MANGROVE_BOAT:
case OAK_BOAT:
case PALE_OAK_BOAT:
case SPRUCE_BOAT:
case BAMBOO_RAFT:
case BAMBOO_CHEST_RAFT:
case ACACIA_CHEST_BOAT:
case BIRCH_CHEST_BOAT:
case CHERRY_CHEST_BOAT:
case DARK_OAK_CHEST_BOAT:
case JUNGLE_CHEST_BOAT:
case MANGROVE_CHEST_BOAT:
case OAK_CHEST_BOAT:
case PALE_OAK_CHEST_BOAT:
case SPRUCE_CHEST_BOAT:
case ALLAY: case ALLAY:
case AXOLOTL: case AXOLOTL:
case BLOCK_DISPLAY: case BLOCK_DISPLAY: