--- a/net/minecraft/server/LootTable.java +++ b/net/minecraft/server/LootTable.java @@ -19,6 +19,13 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +// CraftBukkit start +import java.util.stream.Collectors; +import org.bukkit.craftbukkit.event.CraftEventFactory; +import org.bukkit.craftbukkit.inventory.CraftItemStack; +import org.bukkit.event.world.LootGenerateEvent; +// CraftBukkit end + public class LootTable { private static final Logger LOGGER = LogManager.getLogger(); @@ -103,8 +110,21 @@ } public void fillInventory(IInventory iinventory, LootTableInfo loottableinfo) { + // CraftBukkit start + this.fillInventory(iinventory, loottableinfo, false); + } + + public void fillInventory(IInventory iinventory, LootTableInfo loottableinfo, boolean plugin) { + // CraftBukkit end List list = this.populateLoot(loottableinfo); Random random = loottableinfo.a(); + // CraftBukkit start + LootGenerateEvent event = CraftEventFactory.callLootGenerateEvent(iinventory, this, loottableinfo, list, plugin); + if (event.isCancelled()) { + return; + } + list = event.getLoot().stream().map(CraftItemStack::asNMSCopy).collect(Collectors.toList()); + // CraftBukkit end List list1 = this.a(iinventory, random); this.a(list, list1.size(), random);