diff --git a/src/main/java/world/bentobox/bentobox/listeners/flags/worldsettings/GeoLimitMobsListener.java b/src/main/java/world/bentobox/bentobox/listeners/flags/worldsettings/GeoLimitMobsListener.java index f90f40932..bded3d444 100644 --- a/src/main/java/world/bentobox/bentobox/listeners/flags/worldsettings/GeoLimitMobsListener.java +++ b/src/main/java/world/bentobox/bentobox/listeners/flags/worldsettings/GeoLimitMobsListener.java @@ -4,7 +4,6 @@ import java.util.WeakHashMap; import org.bukkit.Bukkit; -import org.bukkit.entity.Animals; import org.bukkit.entity.Entity; import org.bukkit.entity.Projectile; import org.bukkit.event.EventHandler; @@ -35,10 +34,6 @@ public void onPluginReady(BentoBoxReadyEvent event) { // Kick off the task to remove entities that go outside island boundaries Bukkit.getScheduler().runTaskTimer(getPlugin(), () -> { mobSpawnTracker.entrySet().stream() - // Renamed entities should never be removed. Even if they moved 2k blocks away. - .filter(e -> e.getKey().getCustomName() == null) - // Persistent entities should never be removed, unless they are animals. - .filter(e -> !e.getKey().isPersistent() || e.getKey() instanceof Animals) .filter(e -> !e.getValue().onIsland(e.getKey().getLocation())) .map(Map.Entry::getKey) .forEach(Entity::remove); diff --git a/src/main/java/world/bentobox/bentobox/managers/IslandsManager.java b/src/main/java/world/bentobox/bentobox/managers/IslandsManager.java index f35c9e55e..48c8013f6 100644 --- a/src/main/java/world/bentobox/bentobox/managers/IslandsManager.java +++ b/src/main/java/world/bentobox/bentobox/managers/IslandsManager.java @@ -1386,8 +1386,7 @@ public void clearArea(Location loc) { loc.getWorld().getNearbyEntities(loc, plugin.getSettings().getClearRadius(), plugin.getSettings().getClearRadius(), plugin.getSettings().getClearRadius()).stream() - .filter(en -> !en.isPersistent() - && Util.isHostileEntity(en) + .filter(en -> Util.isHostileEntity(en) && !plugin.getIWM().getRemoveMobsWhitelist(loc.getWorld()).contains(en.getType()) && !(en instanceof PufferFish)) .filter(en -> en.getCustomName() == null)