mirror of
https://hub.spigotmc.org/stash/scm/spigot/spigot.git
synced 2025-04-13 09:32:09 +00:00
86 lines
4.2 KiB
Diff
86 lines
4.2 KiB
Diff
From 519f437fa5bc84f1813b1d4b4c4a5132f0b87776 Mon Sep 17 00:00:00 2001
|
|
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/world/entity/item/EntityItem.java b/src/main/java/net/minecraft/world/entity/item/EntityItem.java
|
|
index d4f6aeced3..15d0290ba7 100644
|
|
--- a/src/main/java/net/minecraft/world/entity/item/EntityItem.java
|
|
+++ b/src/main/java/net/minecraft/world/entity/item/EntityItem.java
|
|
@@ -221,7 +221,10 @@ public class EntityItem extends Entity implements TraceableEntity {
|
|
|
|
private void mergeWithNeighbours() {
|
|
if (this.isMergable()) {
|
|
- List<EntityItem> list = this.level().getEntitiesOfClass(EntityItem.class, this.getBoundingBox().inflate(0.5D, 0.0D, 0.5D), (entityitem) -> {
|
|
+ // Spigot start
|
|
+ double radius = this.level().spigotConfig.itemMerge;
|
|
+ List<EntityItem> list = this.level().getEntitiesOfClass(EntityItem.class, this.getBoundingBox().inflate(radius, radius - 0.5D, radius), (entityitem) -> {
|
|
+ // Spigot end
|
|
return entityitem != this && entityitem.isMergable();
|
|
});
|
|
Iterator iterator = list.iterator();
|
|
@@ -251,7 +254,7 @@ public class EntityItem extends Entity implements TraceableEntity {
|
|
ItemStack itemstack1 = entityitem.getItem();
|
|
|
|
if (Objects.equals(this.target, entityitem.target) && areMergable(itemstack, itemstack1)) {
|
|
- if (itemstack1.getCount() < itemstack.getCount()) {
|
|
+ if (true || itemstack1.getCount() < itemstack.getCount()) { // Spigot
|
|
merge(this, itemstack, entityitem, itemstack1);
|
|
} else {
|
|
merge(entityitem, itemstack1, this, itemstack);
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
|
|
index a5906de1ed..993b594b82 100644
|
|
--- a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
|
|
@@ -691,6 +691,23 @@ public class CraftEventFactory {
|
|
return true;
|
|
}
|
|
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) {
|
|
+ List<Entity> entities = world.getEntities(entity, entity.getBoundingBox().inflate(radius, radius, radius));
|
|
+ for (Entity e : entities) {
|
|
+ if (e instanceof EntityExperienceOrb) {
|
|
+ EntityExperienceOrb loopItem = (EntityExperienceOrb) e;
|
|
+ if (!loopItem.isRemoved()) {
|
|
+ xp.value += loopItem.value;
|
|
+ loopItem.discard();
|
|
+ }
|
|
+ }
|
|
+ }
|
|
+ }
|
|
+ // Spigot end
|
|
} else if (!(entity instanceof EntityPlayer)) {
|
|
event = CraftEventFactory.callEntitySpawnEvent(entity);
|
|
}
|
|
diff --git a/src/main/java/org/spigotmc/SpigotWorldConfig.java b/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
|
index f42972427b..5ff085b9e6 100644
|
|
--- a/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
|
+++ b/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
|
@@ -134,4 +134,18 @@ public class SpigotWorldConfig
|
|
weepingVinesModifier = getAndValidateGrowth( "WeepingVines" );
|
|
caveVinesModifier = getAndValidateGrowth( "CaveVines" );
|
|
}
|
|
+
|
|
+ public double itemMerge;
|
|
+ private void itemMerge()
|
|
+ {
|
|
+ itemMerge = getDouble("merge-radius.item", 2.5 );
|
|
+ log( "Item Merge Radius: " + itemMerge );
|
|
+ }
|
|
+
|
|
+ public double expMerge;
|
|
+ private void expMerge()
|
|
+ {
|
|
+ expMerge = getDouble("merge-radius.exp", 3.0 );
|
|
+ log( "Experience Merge Radius: " + expMerge );
|
|
+ }
|
|
}
|
|
--
|
|
2.42.0
|
|
|