Paper/Spigot-Server-Patches/0029-Fix-lag-from-explosions-processing-dead-entities.patch

30 lines
1.4 KiB
Diff
Raw Normal View History

2018-01-11 13:31:19 +08:00
From d0691988443de01bda2253f429d0d19fe988a125 Mon Sep 17 00:00:00 2001
From: Iceee <andrew@opticgaming.tv>
2016-03-01 07:09:49 +08:00
Date: Wed, 2 Mar 2016 01:39:52 -0600
Subject: [PATCH] Fix lag from explosions processing dead entities
diff --git a/src/main/java/net/minecraft/server/Explosion.java b/src/main/java/net/minecraft/server/Explosion.java
2018-01-11 13:31:19 +08:00
index 98c2bdcf..a1ebcf85 100644
--- a/src/main/java/net/minecraft/server/Explosion.java
+++ b/src/main/java/net/minecraft/server/Explosion.java
2016-11-17 10:23:38 +08:00
@@ -104,7 +104,14 @@ public class Explosion {
int i1 = MathHelper.floor(this.posY + (double) f3 + 1.0D);
int j1 = MathHelper.floor(this.posZ - (double) f3 - 1.0D);
int k1 = MathHelper.floor(this.posZ + (double) f3 + 1.0D);
- List list = this.world.getEntities(this.source, new AxisAlignedBB((double) i, (double) l, (double) j1, (double) j, (double) i1, (double) k1));
2016-03-01 07:09:49 +08:00
+ // Paper start - Fix lag from explosions processing dead entities
2016-05-12 10:07:46 +08:00
+ List list = this.world.getEntities(this.source, new AxisAlignedBB((double) i, (double) l, (double) j1, (double) j, (double) i1, (double) k1), new com.google.common.base.Predicate<Entity>() {
+ @Override
+ public boolean apply(Entity entity) {
+ return IEntitySelector.d.apply(entity) && !entity.dead;
+ }
+ });
2016-03-01 07:09:49 +08:00
+ // Paper end
Vec3D vec3d = new Vec3D(this.posX, this.posY, this.posZ);
for (int l1 = 0; l1 < list.size(); ++l1) {
--
2018-01-11 13:31:19 +08:00
2.14.3