2021-06-11 14:02:28 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Tue, 20 Dec 2016 15:26:27 -0500
|
|
|
|
Subject: [PATCH] Configurable Cartographer Treasure Maps
|
|
|
|
|
|
|
|
Allow configuring for cartographers to return the same map location
|
|
|
|
|
|
|
|
Also allow turning off treasure maps all together as they can eat up Map ID's
|
|
|
|
which are limited in quantity.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
2022-06-06 02:17:27 +02:00
|
|
|
index 0b5e223594ff95b8ba7c300d4a66ca7a17e53802..8451982ba4fc9522f2d77f68fc63a0e12558955f 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
|
|
|
+++ b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
2022-06-06 02:17:27 +02:00
|
|
|
@@ -56,6 +56,11 @@ public class PaperWorldConfig {
|
|
|
|
set("despawn-ranges.hard", null);
|
|
|
|
}
|
|
|
|
|
|
|
|
+ if (this.config.isSet("world-settings.default.treasure-maps-return-already-discovered") || this.config.isSet("world-settings." + worldName + ".treasure-maps-return-already-discovered")) {
|
|
|
|
+ set("treasure-maps-return-already-discovered", null);
|
|
|
|
+ needsSave = true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
if (needsSave) {
|
|
|
|
saveConfig();
|
|
|
|
}
|
|
|
|
@@ -365,4 +370,25 @@ public class PaperWorldConfig {
|
2021-06-11 14:02:28 +02:00
|
|
|
Bukkit.getLogger().warning("Spawn Egg and Armor Stand NBT filtering disabled, this is a potential security risk");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
+
|
|
|
|
+ public boolean enableTreasureMaps = true;
|
2022-06-06 02:17:27 +02:00
|
|
|
+ public boolean treasureMapsAlreadyDiscoveredVillager = false;
|
|
|
|
+ public Boolean treasureMapsAlreadyDiscoveredLootTable = null;
|
|
|
|
+ private Boolean getBooleanOrNull(String path, Boolean defaultValue) {
|
|
|
|
+ this.config.addDefault("world-settings.default." + path, defaultValue == null ? "default" : defaultValue);
|
|
|
|
+ final Object value = this.config.get("world-settings." + worldName + "." + path, this.config.get("world-settings.default." + path));
|
|
|
|
+ if (value instanceof Boolean bool) {
|
|
|
|
+ return bool;
|
|
|
|
+ }
|
|
|
|
+ return null;
|
|
|
|
+ }
|
2021-06-11 14:02:28 +02:00
|
|
|
+ private void treasureMapsAlreadyDiscovered() {
|
|
|
|
+ enableTreasureMaps = getBoolean("enable-treasure-maps", true);
|
2022-06-06 02:17:27 +02:00
|
|
|
+ if (getBoolean("treasure-maps-return-already-discovered", false, false)) {
|
|
|
|
+ treasureMapsAlreadyDiscoveredLootTable = true;
|
|
|
|
+ treasureMapsAlreadyDiscoveredVillager = true;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
2022-06-06 02:17:27 +02:00
|
|
|
+ treasureMapsAlreadyDiscoveredVillager = getBoolean("treasure-maps-find-already-discovered.villager-trade", treasureMapsAlreadyDiscoveredVillager);
|
|
|
|
+ treasureMapsAlreadyDiscoveredLootTable = getBooleanOrNull("treasure-maps-find-already-discovered.loot-tables", treasureMapsAlreadyDiscoveredLootTable);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ }
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/npc/VillagerTrades.java b/src/main/java/net/minecraft/world/entity/npc/VillagerTrades.java
|
2022-06-07 21:55:39 +02:00
|
|
|
index f95999daa1955dd4d919d0e668fe099901a0481c..7360a0a70ddb3dc055d3ebc62071cb5327094e8e 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/npc/VillagerTrades.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/npc/VillagerTrades.java
|
2022-03-01 06:43:03 +01:00
|
|
|
@@ -386,7 +386,8 @@ public class VillagerTrades {
|
2021-06-11 14:02:28 +02:00
|
|
|
return null;
|
|
|
|
} else {
|
2021-06-12 09:24:28 +02:00
|
|
|
ServerLevel serverLevel = (ServerLevel)entity.level;
|
2022-06-07 21:55:39 +02:00
|
|
|
- BlockPos blockPos = serverLevel.findNearestMapStructure(this.destination, entity.blockPosition(), 100, true);
|
2021-06-12 09:24:28 +02:00
|
|
|
+ if (!serverLevel.paperConfig.enableTreasureMaps) return null; // Paper
|
2022-06-07 21:55:39 +02:00
|
|
|
+ BlockPos blockPos = serverLevel.findNearestMapStructure(this.destination, entity.blockPosition(), 100, !serverLevel.paperConfig.treasureMapsAlreadyDiscoveredVillager); // Paper
|
2021-06-12 09:24:28 +02:00
|
|
|
if (blockPos != null) {
|
|
|
|
ItemStack itemStack = MapItem.create(serverLevel, blockPos.getX(), blockPos.getZ(), (byte)2, true, true);
|
|
|
|
MapItem.renderBiomePreviewMap(serverLevel, itemStack);
|
2021-06-11 14:02:28 +02:00
|
|
|
diff --git a/src/main/java/net/minecraft/world/level/storage/loot/functions/ExplorationMapFunction.java b/src/main/java/net/minecraft/world/level/storage/loot/functions/ExplorationMapFunction.java
|
2022-06-07 21:55:39 +02:00
|
|
|
index 321384730cacbdc22eedc53651e4d24f06c73b99..fa1387ce6029198109bed258c559cd008f531c08 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/net/minecraft/world/level/storage/loot/functions/ExplorationMapFunction.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/level/storage/loot/functions/ExplorationMapFunction.java
|
2022-03-01 06:43:03 +01:00
|
|
|
@@ -68,7 +68,16 @@ public class ExplorationMapFunction extends LootItemConditionalFunction {
|
2021-06-12 09:24:28 +02:00
|
|
|
Vec3 vec3 = context.getParamOrNull(LootContextParams.ORIGIN);
|
|
|
|
if (vec3 != null) {
|
|
|
|
ServerLevel serverLevel = context.getLevel();
|
2022-06-07 21:55:39 +02:00
|
|
|
- BlockPos blockPos = serverLevel.findNearestMapStructure(this.destination, new BlockPos(vec3), this.searchRadius, this.skipKnownStructures);
|
2021-06-11 14:02:28 +02:00
|
|
|
+ // Paper start
|
2021-06-12 09:24:28 +02:00
|
|
|
+ if (!serverLevel.paperConfig.enableTreasureMaps) {
|
2021-06-11 14:02:28 +02:00
|
|
|
+ /*
|
|
|
|
+ * NOTE: I fear users will just get a plain map as their "treasure"
|
|
|
|
+ * This is preferable to disrespecting the config.
|
|
|
|
+ */
|
|
|
|
+ return stack;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
2022-06-07 21:55:39 +02:00
|
|
|
+ BlockPos blockPos = serverLevel.findNearestMapStructure(this.destination, new BlockPos(vec3), this.searchRadius, serverLevel.paperConfig.treasureMapsAlreadyDiscoveredLootTable == null ? this.skipKnownStructures : serverLevel.paperConfig.treasureMapsAlreadyDiscoveredLootTable); // Paper
|
2021-06-12 09:24:28 +02:00
|
|
|
if (blockPos != null) {
|
|
|
|
ItemStack itemStack = MapItem.create(serverLevel, blockPos.getX(), blockPos.getZ(), this.zoom, true, true);
|
|
|
|
MapItem.renderBiomePreviewMap(serverLevel, itemStack);
|