From 5c4d5afef1970528d5f7e915d3ad582e1f7013e1 Mon Sep 17 00:00:00 2001 From: lexikiq Date: Mon, 21 Jun 2021 23:21:58 -0400 Subject: [PATCH] Preserve overstacked loot Preserves overstacked items in loot tables, such as shulker box drops, to prevent the items from being deleted (as they'd overflow past the bounds of the container)-- or worse, causing chunk bans via the large amount of NBT created by unstacking the items. Fixes GH-5140 and GH-4748. --- .../level/storage/loot/LootTable.java.patch | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/paper-server/patches/sources/net/minecraft/world/level/storage/loot/LootTable.java.patch b/paper-server/patches/sources/net/minecraft/world/level/storage/loot/LootTable.java.patch index ae76a3e0e5..29133b2303 100644 --- a/paper-server/patches/sources/net/minecraft/world/level/storage/loot/LootTable.java.patch +++ b/paper-server/patches/sources/net/minecraft/world/level/storage/loot/LootTable.java.patch @@ -22,7 +22,19 @@ LootTable(ContextKeySet type, Optional randomSequenceId, List pools, List functions) { this.paramSet = type; -@@ -157,10 +165,23 @@ +@@ -64,9 +72,10 @@ + } + + public static Consumer createStackSplitter(ServerLevel world, Consumer consumer) { ++ boolean skipSplitter = world != null && !world.paperConfig().fixes.splitOverstackedLoot; // Paper - preserve overstacked items + return (itemstack) -> { + if (itemstack.isItemEnabled(world.enabledFeatures())) { +- if (itemstack.getCount() < itemstack.getMaxStackSize()) { ++ if (skipSplitter || itemstack.getCount() < itemstack.getMaxStackSize()) { // Paper - preserve overstacked items + consumer.accept(itemstack); + } else { + int i = itemstack.getCount(); +@@ -157,10 +166,23 @@ } public void fill(Container inventory, LootParams parameters, long seed) { @@ -48,7 +60,7 @@ this.shuffleAndSplitItems(objectarraylist, list.size(), randomsource); ObjectListIterator objectlistiterator = objectarraylist.iterator(); -@@ -174,9 +195,9 @@ +@@ -174,9 +196,9 @@ } if (itemstack.isEmpty()) { @@ -60,7 +72,7 @@ } } -@@ -238,8 +259,8 @@ +@@ -238,8 +260,8 @@ public static class Builder implements FunctionUserBuilder {