2023-08-20 19:30:45 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
|
|
|
Date: Sat, 10 Dec 2022 17:52:38 -0800
|
|
|
|
Subject: [PATCH] Deprecate and replace methods with old StructureType
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
2024-05-11 23:48:37 +02:00
|
|
|
index 89b7dfcb22c2e59aa5723551f881b975544a0ab5..58c0778741a14c252ee01536b6fd9a3c5bcbc58f 100644
|
2023-08-20 19:30:45 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
2024-05-11 23:48:37 +02:00
|
|
|
@@ -1970,6 +1970,11 @@ public final class CraftServer implements Server {
|
2023-08-20 19:30:45 +02:00
|
|
|
|
|
|
|
ServerLevel worldServer = ((CraftWorld) world).getHandle();
|
|
|
|
Location structureLocation = world.locateNearestStructure(location, structureType, radius, findUnexplored);
|
|
|
|
+ // Paper start - don't throw NPE
|
|
|
|
+ if (structureLocation == null) {
|
|
|
|
+ throw new IllegalStateException("Could not find a structure for " + structureType);
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
BlockPos structurePosition = CraftLocation.toBlockPosition(structureLocation);
|
|
|
|
|
|
|
|
// Create map with trackPlayer = true, unlimitedTracking = true
|
2024-05-11 23:48:37 +02:00
|
|
|
@@ -1980,6 +1985,31 @@ public final class CraftServer implements Server {
|
2023-08-20 19:30:45 +02:00
|
|
|
|
|
|
|
return CraftItemStack.asBukkitCopy(stack);
|
|
|
|
}
|
|
|
|
+ // Paper start - copied from above (uses un-deprecated StructureType type)
|
|
|
|
+ @Override
|
|
|
|
+ public ItemStack createExplorerMap(World world, Location location, org.bukkit.generator.structure.StructureType structureType, org.bukkit.map.MapCursor.Type mapIcon, int radius, boolean findUnexplored) {
|
|
|
|
+ Preconditions.checkArgument(world != null, "World cannot be null");
|
|
|
|
+ Preconditions.checkArgument(location != null, "Location cannot be null");
|
|
|
|
+ Preconditions.checkArgument(structureType != null, "StructureType cannot be null");
|
|
|
|
+ Preconditions.checkArgument(mapIcon != null, "mapIcon cannot be null");
|
|
|
|
+
|
|
|
|
+ ServerLevel worldServer = ((CraftWorld) world).getHandle();
|
|
|
|
+ final org.bukkit.util.StructureSearchResult structureSearchResult = world.locateNearestStructure(location, structureType, radius, findUnexplored);
|
|
|
|
+ if (structureSearchResult == null) {
|
|
|
|
+ return null;
|
|
|
|
+ }
|
|
|
|
+ Location structureLocation = structureSearchResult.getLocation();
|
|
|
|
+ BlockPos structurePosition = new BlockPos(structureLocation.getBlockX(), structureLocation.getBlockY(), structureLocation.getBlockZ());
|
|
|
|
+
|
|
|
|
+ // Create map with showIcons = true, unlimitedTracking = true
|
|
|
|
+ net.minecraft.world.item.ItemStack stack = MapItem.create(worldServer, structurePosition.getX(), structurePosition.getZ(), MapView.Scale.NORMAL.getValue(), true, true);
|
|
|
|
+ MapItem.renderBiomePreviewMap(worldServer, stack);
|
|
|
|
+ // "+" map ID taken from VillagerTrades$TreasureMapForEmeralds
|
2024-04-25 05:40:32 +02:00
|
|
|
+ MapItem.getSavedData(stack, worldServer).addTargetDecoration(stack, structurePosition, "+", CraftMapCursor.CraftType.bukkitToMinecraftHolder(mapIcon));
|
2023-08-20 19:30:45 +02:00
|
|
|
+
|
|
|
|
+ return CraftItemStack.asBukkitCopy(stack);
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void shutdown() {
|