geforkt von Mirrors/Paper
SPIGOT-7800, SPIGOT-7801: Keep vanilla behaviour for items dropped on player death
By: Doc <nachito94@msn.com>
Dieser Commit ist enthalten in:
Ursprung
5f8cff3bb5
Commit
8821aa372c
@ -331,7 +331,7 @@
|
|||||||
+ if (this.isRemoved()) {
|
+ if (this.isRemoved()) {
|
||||||
+ return;
|
+ return;
|
||||||
+ }
|
+ }
|
||||||
+ java.util.List<org.bukkit.inventory.ItemStack> loot = new java.util.ArrayList<org.bukkit.inventory.ItemStack>(this.getInventory().getContainerSize());
|
+ java.util.List<org.bukkit.inventory.ItemStack> loot = new java.util.ArrayList<>(this.getInventory().getContainerSize());
|
||||||
+ boolean keepInventory = this.level().getGameRules().getBoolean(GameRules.RULE_KEEPINVENTORY) || this.isSpectator();
|
+ boolean keepInventory = this.level().getGameRules().getBoolean(GameRules.RULE_KEEPINVENTORY) || this.isSpectator();
|
||||||
|
|
||||||
- if (flag) {
|
- if (flag) {
|
||||||
@ -345,9 +345,9 @@
|
|||||||
+ }
|
+ }
|
||||||
+ // SPIGOT-5071: manually add player loot tables (SPIGOT-5195 - ignores keepInventory rule)
|
+ // SPIGOT-5071: manually add player loot tables (SPIGOT-5195 - ignores keepInventory rule)
|
||||||
+ this.dropFromLootTable(damagesource, this.lastHurtByPlayerTime > 0);
|
+ this.dropFromLootTable(damagesource, this.lastHurtByPlayerTime > 0);
|
||||||
+ for (org.bukkit.inventory.ItemStack item : this.drops) {
|
+ this.dropCustomDeathLoot(this.serverLevel(), damagesource, flag);
|
||||||
+ loot.add(item);
|
+
|
||||||
+ }
|
+ loot.addAll(this.drops);
|
||||||
+ this.drops.clear(); // SPIGOT-5188: make sure to clear
|
+ this.drops.clear(); // SPIGOT-5188: make sure to clear
|
||||||
+
|
+
|
||||||
+ IChatBaseComponent defaultMessage = this.getCombatTracker().getDeathMessage();
|
+ IChatBaseComponent defaultMessage = this.getCombatTracker().getDeathMessage();
|
||||||
@ -1058,7 +1058,23 @@
|
|||||||
if (blockposition != null) {
|
if (blockposition != null) {
|
||||||
boolean flag2 = blockposition.equals(this.respawnPosition) && resourcekey.equals(this.respawnDimension);
|
boolean flag2 = blockposition.equals(this.respawnPosition) && resourcekey.equals(this.respawnDimension);
|
||||||
|
|
||||||
@@ -2049,10 +2500,12 @@
|
@@ -1852,7 +2303,14 @@
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EntityItem drop(ItemStack itemstack, boolean flag, boolean flag1) {
|
||||||
|
- EntityItem entityitem = super.drop(itemstack, flag, flag1);
|
||||||
|
+ // CraftBukkit start - SPIGOT-2942: Add boolean to call event
|
||||||
|
+ return drop(itemstack, flag, flag1, true);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public EntityItem drop(ItemStack itemstack, boolean flag, boolean flag1, boolean callEvent) {
|
||||||
|
+ EntityItem entityitem = super.drop(itemstack, flag, flag1, callEvent);
|
||||||
|
+ // CraftBukkit end
|
||||||
|
|
||||||
|
if (entityitem == null) {
|
||||||
|
return null;
|
||||||
|
@@ -2049,10 +2507,12 @@
|
||||||
this.awardStat(StatisticList.ITEM_BROKEN.get(item));
|
this.awardStat(StatisticList.ITEM_BROKEN.get(item));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1074,7 +1090,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static float calculateLookAtYaw(Vec3D vec3d, BlockPosition blockposition) {
|
private static float calculateLookAtYaw(Vec3D vec3d, BlockPosition blockposition) {
|
||||||
@@ -2061,4 +2514,147 @@
|
@@ -2061,4 +2521,147 @@
|
||||||
return (float) MathHelper.wrapDegrees(MathHelper.atan2(vec3d1.z, vec3d1.x) * 57.2957763671875D - 90.0D);
|
return (float) MathHelper.wrapDegrees(MathHelper.atan2(vec3d1.z, vec3d1.x) * 57.2957763671875D - 90.0D);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -910,7 +910,6 @@ public class CraftEventFactory {
|
|||||||
PlayerDeathEvent event = new PlayerDeathEvent(entity, bukkitDamageSource, drops, victim.getExpReward(damageSource.getEntity()), 0, deathMessage);
|
PlayerDeathEvent event = new PlayerDeathEvent(entity, bukkitDamageSource, drops, victim.getExpReward(damageSource.getEntity()), 0, deathMessage);
|
||||||
event.setKeepInventory(keepInventory);
|
event.setKeepInventory(keepInventory);
|
||||||
event.setKeepLevel(victim.keepLevel); // SPIGOT-2222: pre-set keepLevel
|
event.setKeepLevel(victim.keepLevel); // SPIGOT-2222: pre-set keepLevel
|
||||||
org.bukkit.World world = entity.getWorld();
|
|
||||||
Bukkit.getServer().getPluginManager().callEvent(event);
|
Bukkit.getServer().getPluginManager().callEvent(event);
|
||||||
|
|
||||||
victim.keepLevel = event.getKeepLevel();
|
victim.keepLevel = event.getKeepLevel();
|
||||||
@ -922,7 +921,7 @@ public class CraftEventFactory {
|
|||||||
for (org.bukkit.inventory.ItemStack stack : event.getDrops()) {
|
for (org.bukkit.inventory.ItemStack stack : event.getDrops()) {
|
||||||
if (stack == null || stack.getType() == Material.AIR) continue;
|
if (stack == null || stack.getType() == Material.AIR) continue;
|
||||||
|
|
||||||
world.dropItem(entity.getLocation(), stack);
|
victim.drop(CraftItemStack.asNMSCopy(stack), true, false, false); // SPIGOT-7800, SPIGOT-7801: Vanilla Behaviour for dropped items
|
||||||
}
|
}
|
||||||
|
|
||||||
return event;
|
return event;
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren