spigot/CraftBukkit-Patches/0006-Merge-tweaks-and-configuration.patch

87 lines
4.1 KiB
Diff
Raw Normal View History

2019-06-21 20:00:00 +10:00
From fdcf9611d8f85dd87336d9fe794b635fbeb582aa Mon Sep 17 00:00:00 2001
2013-03-23 09:48:22 +11:00
From: md_5 <md_5@live.com.au>
Date: Sat, 23 Mar 2013 09:46:33 +1100
Subject: [PATCH] Merge tweaks and configuration
This allows the merging of Experience orbs, as well as the configuration of the merge radius of items. Additionally it refactors the merge algorithm to be a better experience for players.
diff --git a/src/main/java/net/minecraft/server/EntityItem.java b/src/main/java/net/minecraft/server/EntityItem.java
2019-06-21 20:00:00 +10:00
index cd31e3c73..cc831fca8 100644
2013-03-23 09:48:22 +11:00
--- a/src/main/java/net/minecraft/server/EntityItem.java
+++ b/src/main/java/net/minecraft/server/EntityItem.java
2019-05-14 10:00:00 +10:00
@@ -144,7 +144,10 @@ public class EntityItem extends Entity {
2013-03-23 09:48:22 +11:00
}
2019-04-23 12:00:00 +10:00
private void mergeNearby() {
- List<EntityItem> list = this.world.a(EntityItem.class, this.getBoundingBox().grow(0.5D, 0.0D, 0.5D), (entityitem) -> {
2013-03-23 09:48:22 +11:00
+ // Spigot start
2013-06-21 17:00:01 +10:00
+ double radius = world.spigotConfig.itemMerge;
2019-04-23 12:00:00 +10:00
+ List<EntityItem> list = this.world.a(EntityItem.class, this.getBoundingBox().grow(radius, radius, radius), (entityitem) -> {
+ // Spigot end
return entityitem != this && entityitem.z();
});
2013-03-23 09:48:22 +11:00
2019-05-14 10:00:00 +10:00
@@ -178,7 +181,7 @@ public class EntityItem extends Entity {
2019-04-23 12:00:00 +10:00
if (itemstack1.getCount() + itemstack.getCount() <= itemstack1.getMaxStackSize()) {
if (!(itemstack1.hasTag() ^ itemstack.hasTag())) {
if (!itemstack1.hasTag() || itemstack1.getTag().equals(itemstack.getTag())) {
- if (itemstack1.getCount() < itemstack.getCount()) {
+ if (true || itemstack1.getCount() < itemstack.getCount()) { // Spigot
a(this, itemstack, entityitem, itemstack1);
} else {
a(entityitem, itemstack1, this, itemstack);
2018-12-17 12:35:20 +11:00
diff --git a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
2019-06-21 20:00:00 +10:00
index a09240d8a..78a2639d3 100644
2018-12-17 12:35:20 +11:00
--- a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
+++ b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
2019-05-28 06:30:00 +10:00
@@ -521,6 +521,23 @@ public class CraftEventFactory {
2018-12-26 08:00:00 +11:00
event = CraftEventFactory.callProjectileLaunchEvent(entity);
2017-03-15 20:51:00 +11:00
} else if (entity.getBukkitEntity() instanceof org.bukkit.entity.Vehicle){
event = CraftEventFactory.callVehicleCreateEvent(entity);
2013-03-23 09:48:22 +11:00
+ // Spigot start
2018-12-26 08:00:00 +11:00
+ } else if (entity instanceof EntityExperienceOrb) {
2013-03-23 09:48:22 +11:00
+ EntityExperienceOrb xp = (EntityExperienceOrb) entity;
2018-12-17 12:35:20 +11:00
+ double radius = world.spigotConfig.expMerge;
2013-03-23 09:48:22 +11:00
+ if (radius > 0) {
2018-12-17 12:35:20 +11:00
+ List<Entity> entities = world.getEntities(entity, entity.getBoundingBox().grow(radius, radius, radius));
2013-03-23 09:48:22 +11:00
+ for (Entity e : entities) {
+ if (e instanceof EntityExperienceOrb) {
+ EntityExperienceOrb loopItem = (EntityExperienceOrb) e;
+ if (!loopItem.dead) {
+ xp.value += loopItem.value;
+ loopItem.die();
+ }
+ }
+ }
+ }
2018-12-26 08:00:00 +11:00
+ // Spigot end
2019-03-26 20:48:00 +11:00
} else if (!(entity instanceof EntityPlayer)) {
2018-12-26 08:00:00 +11:00
event = CraftEventFactory.callEntitySpawnEvent(entity);
}
2013-06-20 18:41:59 +10:00
diff --git a/src/main/java/org/spigotmc/SpigotWorldConfig.java b/src/main/java/org/spigotmc/SpigotWorldConfig.java
index a7a71fec0..b07e6098e 100644
2013-06-20 18:41:59 +10:00
--- a/src/main/java/org/spigotmc/SpigotWorldConfig.java
+++ b/src/main/java/org/spigotmc/SpigotWorldConfig.java
@@ -116,4 +116,18 @@ public class SpigotWorldConfig
vineModifier = getAndValidateGrowth( "Vine" );
cocoaModifier = getAndValidateGrowth( "Cocoa" );
2013-06-20 18:41:59 +10:00
}
+
2013-06-21 17:00:01 +10:00
+ public double itemMerge;
2013-06-20 18:41:59 +10:00
+ private void itemMerge()
+ {
2013-06-21 17:00:01 +10:00
+ itemMerge = getDouble("merge-radius.item", 2.5 );
2013-06-20 18:41:59 +10:00
+ log( "Item Merge Radius: " + itemMerge );
+ }
+
2013-06-21 17:00:01 +10:00
+ public double expMerge;
2013-06-20 18:41:59 +10:00
+ private void expMerge()
+ {
2013-06-21 17:00:01 +10:00
+ expMerge = getDouble("merge-radius.exp", 3.0 );
2013-06-20 18:41:59 +10:00
+ log( "Experience Merge Radius: " + expMerge );
+ }
}
2013-03-23 09:48:22 +11:00
--
2019-04-23 09:33:25 +10:00
2.20.1
2013-03-23 09:48:22 +11:00