2022-02-25 16:46:35 +00:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
2022-06-03 04:42:00 +00:00
From: Jake Potrebic <jake.m.potrebic@gmail.com>
2022-02-25 16:46:35 +00:00
Date: Fri, 25 Feb 2022 07:14:48 -0800
2022-03-01 03:25:13 +00:00
Subject: [PATCH] CB fixes
2022-02-25 16:46:35 +00:00
2022-03-01 03:25:13 +00:00
* Missing Level -> LevelStem generic in StructureCheck
2022-06-03 04:42:00 +00:00
Need to use the right for injectDatafixingContext (Spottedleaf)
2022-02-25 16:46:35 +00:00
2022-06-03 04:42:00 +00:00
* Removed incorrect parent perm for `minecraft.debugstick.always` (Machine_Maker)
2022-05-24 04:09:20 +00:00
2022-06-03 04:42:00 +00:00
* Fixed method signature of Marker#addPassenger (Machine_Maker)
2022-05-26 01:00:47 +00:00
2022-06-03 04:42:00 +00:00
* Removed unneeded UOE in CustomWorldChunkManager (extends BiomeSource) (Machine_Maker)
* Honor Server#getLootTable method contract (Machine_Maker)
Co-authored-by: Spottedleaf <Spottedleaf@users.noreply.github.com>
2022-05-31 02:35:46 +00:00
2022-02-25 16:46:35 +00:00
diff --git a/src/main/java/net/minecraft/server/level/ServerLevel.java b/src/main/java/net/minecraft/server/level/ServerLevel.java
2023-09-22 12:33:54 +00:00
index f3a41559be5ad0b40762d368d8582704c8305961..32565740c6b013d9ad644e7c62d6721bdbd15b10 100644
2022-02-25 16:46:35 +00:00
--- a/src/main/java/net/minecraft/server/level/ServerLevel.java
+++ b/src/main/java/net/minecraft/server/level/ServerLevel.java
2023-09-21 17:39:51 +00:00
@@ -294,7 +294,7 @@ public class ServerLevel extends Level implements WorldGenLevel {
2022-02-25 16:46:35 +00:00
2022-12-07 17:08:55 +00:00
long l = minecraftserver.getWorldData().worldGenOptions().seed();
2022-02-25 16:46:35 +00:00
2022-06-07 18:12:34 +00:00
- this.structureCheck = new StructureCheck(this.chunkSource.chunkScanner(), this.registryAccess(), minecraftserver.getStructureManager(), resourcekey, chunkgenerator, this.chunkSource.randomState(), this, chunkgenerator.getBiomeSource(), l, datafixer);
+ this.structureCheck = new StructureCheck(this.chunkSource.chunkScanner(), this.registryAccess(), minecraftserver.getStructureManager(), this.getTypeKey(), chunkgenerator, this.chunkSource.randomState(), this, chunkgenerator.getBiomeSource(), l, datafixer); // Paper - Fix missing CB diff
2022-12-07 17:08:55 +00:00
this.structureManager = new StructureManager(this, this.serverLevelData.worldGenOptions(), this.structureCheck); // CraftBukkit
2022-06-20 17:12:05 +00:00
if ((this.dimension() == Level.END && this.dimensionTypeRegistration().is(BuiltinDimensionTypes.END)) || env == org.bukkit.World.Environment.THE_END) { // CraftBukkit - Allow to create EnderDragonBattle in default and custom END
2022-12-07 17:08:55 +00:00
this.dragonFight = new EndDragonFight(this, this.serverLevelData.worldGenOptions().seed(), this.serverLevelData.endDragonFightData()); // CraftBukkit
2022-12-09 02:17:06 +00:00
diff --git a/src/main/java/net/minecraft/world/entity/animal/camel/Camel.java b/src/main/java/net/minecraft/world/entity/animal/camel/Camel.java
2023-09-22 17:59:56 +00:00
index 869f60e9407ed1c5bee536ef91a21f4d11f8f964..3aa98f7c282cb4884589cb83b1546b924e66f096 100644
2022-12-09 02:17:06 +00:00
--- a/src/main/java/net/minecraft/world/entity/animal/camel/Camel.java
+++ b/src/main/java/net/minecraft/world/entity/animal/camel/Camel.java
2023-09-21 17:39:51 +00:00
@@ -445,9 +445,9 @@ public class Camel extends AbstractHorse implements PlayerRideableJumping, Saddl
2022-12-09 02:17:06 +00:00
}
@Override
- protected void actuallyHurt(DamageSource source, float amount) {
+ protected boolean damageEntity0(DamageSource source, float amount) { // Paper - fix CB method rename issue
2023-06-07 16:24:39 +00:00
this.standUpInstantly();
2022-12-09 02:17:06 +00:00
- super.actuallyHurt(source, amount);
+ return super.damageEntity0(source, amount); // Paper - fix CB method rename issue
}
2022-05-26 01:00:47 +00:00
@Override
2022-02-25 16:46:35 +00:00
diff --git a/src/main/java/net/minecraft/world/level/levelgen/structure/StructureCheck.java b/src/main/java/net/minecraft/world/level/levelgen/structure/StructureCheck.java
2023-09-22 17:59:56 +00:00
index 161ad6ab1443b2ce33a2d7d91d189c855db0453b..15a9736a870055d639d03063c7cf67fd769fff36 100644
2022-02-25 16:46:35 +00:00
--- a/src/main/java/net/minecraft/world/level/levelgen/structure/StructureCheck.java
+++ b/src/main/java/net/minecraft/world/level/levelgen/structure/StructureCheck.java
2023-03-14 18:05:23 +00:00
@@ -43,7 +43,7 @@ public class StructureCheck {
2022-02-25 16:46:35 +00:00
private final Registry<Biome> biomes;
2022-06-07 18:12:34 +00:00
private final Registry<Structure> structureConfigs;
private final StructureTemplateManager structureTemplateManager;
2022-02-25 16:46:35 +00:00
- private final ResourceKey<Level> dimension;
+ private final ResourceKey<net.minecraft.world.level.dimension.LevelStem> dimension; // Paper - fix missing CB diff
private final ChunkGenerator chunkGenerator;
2022-06-07 18:12:34 +00:00
private final RandomState randomState;
2022-02-25 16:46:35 +00:00
private final LevelHeightAccessor heightAccessor;
2023-03-14 18:05:23 +00:00
@@ -53,7 +53,7 @@ public class StructureCheck {
2022-06-07 18:12:34 +00:00
private final Long2ObjectMap<Object2IntMap<Structure>> loadedChunks = new Long2ObjectOpenHashMap<>();
private final Map<Structure, Long2BooleanMap> featureChecks = new HashMap<>();
2022-02-25 16:46:35 +00:00
2022-06-07 18:12:34 +00:00
- public StructureCheck(ChunkScanAccess chunkIoWorker, RegistryAccess registryManager, StructureTemplateManager structureTemplateManager, ResourceKey<Level> worldKey, ChunkGenerator chunkGenerator, RandomState noiseConfig, LevelHeightAccessor world, BiomeSource biomeSource, long seed, DataFixer dataFixer) {
+ public StructureCheck(ChunkScanAccess chunkIoWorker, RegistryAccess registryManager, StructureTemplateManager structureTemplateManager, ResourceKey<net.minecraft.world.level.dimension.LevelStem> worldKey, ChunkGenerator chunkGenerator, RandomState noiseConfig, LevelHeightAccessor world, BiomeSource biomeSource, long seed, DataFixer dataFixer) { // Paper - fix missing CB diff
2022-02-25 16:46:35 +00:00
this.storageAccess = chunkIoWorker;
this.registryAccess = registryManager;
2022-06-07 18:12:34 +00:00
this.structureTemplateManager = structureTemplateManager;
2022-06-03 04:42:00 +00:00
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
2023-09-21 17:39:51 +00:00
index cbfc9b90805ecce074d42cfeb0b68d84cdafcac6..35f0be0afad8f88f69c3127d1bd44bb0e12af550 100644
2022-06-03 04:42:00 +00:00
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
+++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
2023-09-21 17:39:51 +00:00
@@ -2360,7 +2360,13 @@ public final class CraftServer implements Server {
2023-06-12 23:51:45 +00:00
Preconditions.checkArgument(key != null, "NamespacedKey key cannot be null");
2022-06-03 04:42:00 +00:00
2023-06-07 16:24:39 +00:00
LootDataManager registry = this.getServer().getLootData();
- return new CraftLootTable(key, registry.getLootTable(CraftNamespacedKey.toMinecraft(key)));
2022-06-03 04:42:00 +00:00
+ // Paper start - honor method contract
+ final ResourceLocation lootTableKey = CraftNamespacedKey.toMinecraft(key);
2023-06-07 16:24:39 +00:00
+ if (registry.getLootTable(lootTableKey) == net.minecraft.world.level.storage.loot.LootTable.EMPTY) {
2022-06-03 04:42:00 +00:00
+ return null;
+ }
2023-06-07 16:24:39 +00:00
+ return new CraftLootTable(key, registry.getLootTable(lootTableKey));
2022-06-03 04:42:00 +00:00
+ // Paper end
}
2022-05-31 02:35:46 +00:00
@Override
2022-05-24 04:09:20 +00:00
diff --git a/src/main/java/org/bukkit/craftbukkit/util/permissions/CraftDefaultPermissions.java b/src/main/java/org/bukkit/craftbukkit/util/permissions/CraftDefaultPermissions.java
index c93eec7a81ed83dc9190417dd51acb2780d3b60d..70d3949616c63038ad3e9bd1069db5ea2fb3f3b8 100644
--- a/src/main/java/org/bukkit/craftbukkit/util/permissions/CraftDefaultPermissions.java
+++ b/src/main/java/org/bukkit/craftbukkit/util/permissions/CraftDefaultPermissions.java
@@ -15,7 +15,7 @@ public final class CraftDefaultPermissions {
DefaultPermissions.registerPermission(CraftDefaultPermissions.ROOT + ".nbt.place", "Gives the user the ability to place restricted blocks with NBT in creative", org.bukkit.permissions.PermissionDefault.OP, parent);
DefaultPermissions.registerPermission(CraftDefaultPermissions.ROOT + ".nbt.copy", "Gives the user the ability to copy NBT in creative", org.bukkit.permissions.PermissionDefault.TRUE, parent);
DefaultPermissions.registerPermission(CraftDefaultPermissions.ROOT + ".debugstick", "Gives the user the ability to use the debug stick in creative", org.bukkit.permissions.PermissionDefault.OP, parent);
- DefaultPermissions.registerPermission(CraftDefaultPermissions.ROOT + ".debugstick.always", "Gives the user the ability to use the debug stick in all game modes", org.bukkit.permissions.PermissionDefault.FALSE, parent);
+ DefaultPermissions.registerPermission(CraftDefaultPermissions.ROOT + ".debugstick.always", "Gives the user the ability to use the debug stick in all game modes", org.bukkit.permissions.PermissionDefault.FALSE/* , parent */); // Paper - should not have this parent, as it's not a "vanilla" utility
// Spigot end
parent.recalculatePermissibles();
}