2023-06-12 19:41:07 +10:00
From 650ac4c6c14bb7521e5f676b286a492706efed3b 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.
2021-03-16 09:00:00 +11:00
diff --git a/src/main/java/net/minecraft/world/entity/item/EntityItem.java b/src/main/java/net/minecraft/world/entity/item/EntityItem.java
2023-06-08 01:30:00 +10:00
index 1d4abea14..0ee3d963c 100644
2021-03-16 09:00:00 +11:00
--- a/src/main/java/net/minecraft/world/entity/item/EntityItem.java
+++ b/src/main/java/net/minecraft/world/entity/item/EntityItem.java
2023-06-08 01:30:00 +10:00
@@ -219,7 +219,10 @@ public class EntityItem extends Entity implements TraceableEntity {
2013-03-23 09:48:22 +11:00
2021-11-22 09:00:00 +11:00
private void mergeWithNeighbours() {
if (this.isMergable()) {
2023-06-08 01:30:00 +10:00
- List<EntityItem> list = this.level().getEntitiesOfClass(EntityItem.class, this.getBoundingBox().inflate(0.5D, 0.0D, 0.5D), (entityitem) -> {
2019-12-11 09:00:00 +11:00
+ // Spigot start
2023-06-08 01:30:00 +10:00
+ double radius = this.level().spigotConfig.itemMerge;
+ List<EntityItem> list = this.level().getEntitiesOfClass(EntityItem.class, this.getBoundingBox().inflate(radius, radius - 0.5D, radius), (entityitem) -> {
2019-12-11 09:00:00 +11:00
+ // Spigot end
2021-11-22 09:00:00 +11:00
return entityitem != this && entityitem.isMergable();
2019-12-11 09:00:00 +11:00
});
Iterator iterator = list.iterator();
2023-06-08 01:30:00 +10:00
@@ -249,7 +252,7 @@ public class EntityItem extends Entity implements TraceableEntity {
2021-11-22 09:00:00 +11:00
ItemStack itemstack1 = entityitem.getItem();
2013-03-23 09:48:22 +11:00
2023-03-15 03:30:00 +11:00
if (Objects.equals(this.target, entityitem.target) && areMergable(itemstack, itemstack1)) {
2019-12-11 09:00:00 +11:00
- if (itemstack1.getCount() < itemstack.getCount()) {
+ if (true || itemstack1.getCount() < itemstack.getCount()) { // Spigot
2021-11-22 09:00:00 +11:00
merge(this, itemstack, entityitem, itemstack1);
2019-12-11 09:00:00 +11:00
} else {
2021-11-22 09:00:00 +11:00
merge(entityitem, itemstack1, this, itemstack);
2021-06-11 17:08:01 +10:00
diff --git a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
2023-06-12 19:41:07 +10:00
index 222a92eb8..90a150ced 100644
2021-06-11 17:08:01 +10:00
--- a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
+++ b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
2023-06-12 19:41:07 +10:00
@@ -651,6 +651,23 @@ public class CraftEventFactory {
2021-07-13 19:18:55 +10:00
return true;
}
2021-06-11 17:08:01 +10:00
event = CraftEventFactory.callLightningStrikeEvent((LightningStrike) entity.getBukkitEntity(), cause);
+ // Spigot start
+ } else if (entity instanceof EntityExperienceOrb) {
+ EntityExperienceOrb xp = (EntityExperienceOrb) entity;
+ double radius = world.spigotConfig.expMerge;
+ if (radius > 0) {
2021-11-22 09:00:00 +11:00
+ List<Entity> entities = world.getEntities(entity, entity.getBoundingBox().inflate(radius, radius, radius));
2021-06-11 17:08:01 +10:00
+ for (Entity e : entities) {
+ if (e instanceof EntityExperienceOrb) {
+ EntityExperienceOrb loopItem = (EntityExperienceOrb) e;
+ if (!loopItem.isRemoved()) {
+ xp.value += loopItem.value;
2021-11-22 09:00:00 +11:00
+ loopItem.discard();
2021-06-11 17:08:01 +10:00
+ }
+ }
+ }
+ }
+ // Spigot end
} else if (!(entity instanceof EntityPlayer)) {
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
2023-06-08 01:30:00 +10:00
index f42972427..5ff085b9e 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
2022-10-20 07:31:42 +11:00
@@ -134,4 +134,18 @@ public class SpigotWorldConfig
weepingVinesModifier = getAndValidateGrowth( "WeepingVines" );
caveVinesModifier = getAndValidateGrowth( "CaveVines" );
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
--
2023-05-11 07:10:33 +10:00
2.40.1
2013-03-23 09:48:22 +11:00