2013-07-02 05:03:56 +02:00
From dcf697293680dd7593a8e1f92ac65b36c7be48db Mon Sep 17 00:00:00 2001
2013-03-22 23:48:22 +01: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
2013-07-02 05:03:56 +02:00
index cb2b114..6895b53 100644
2013-03-22 23:48:22 +01:00
--- a/src/main/java/net/minecraft/server/EntityItem.java
+++ b/src/main/java/net/minecraft/server/EntityItem.java
2013-07-02 05:03:56 +02:00
@@ -112,7 +112,10 @@ public class EntityItem extends Entity {
2013-03-22 23:48:22 +01:00
}
2013-07-02 05:03:56 +02:00
private void e() {
2013-03-22 23:48:22 +01:00
- Iterator iterator = this.world.a(EntityItem.class, this.boundingBox.grow(0.5D, 0.0D, 0.5D)).iterator();
+ // Spigot start
2013-06-21 09:00:01 +02:00
+ double radius = world.spigotConfig.itemMerge;
2013-03-22 23:48:22 +01:00
+ Iterator iterator = this.world.a(EntityItem.class, this.boundingBox.grow(radius, radius, radius)).iterator();
+ // Spigot end
while (iterator.hasNext()) {
EntityItem entityitem = (EntityItem) iterator.next();
2013-07-02 05:03:56 +02:00
@@ -141,11 +144,13 @@ public class EntityItem extends Entity {
2013-03-22 23:48:22 +01:00
} else if (itemstack1.count + itemstack.count > itemstack1.getMaxStackSize()) {
return false;
} else {
- itemstack1.count += itemstack.count;
- entityitem.pickupDelay = Math.max(entityitem.pickupDelay, this.pickupDelay);
- entityitem.age = Math.min(entityitem.age, this.age);
- entityitem.setItemStack(itemstack1);
- this.die();
+ // Spigot start
+ itemstack.count += itemstack1.count;
+ this.pickupDelay = Math.max(entityitem.pickupDelay, this.pickupDelay);
+ this.age = Math.min(entityitem.age, this.age);
+ this.setItemStack(itemstack);
+ entityitem.die();
+ // Spigot end
return true;
}
} else {
diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java
2013-07-02 05:03:56 +02:00
index 18994b6..3e7c493 100644
2013-03-22 23:48:22 +01:00
--- a/src/main/java/net/minecraft/server/World.java
+++ b/src/main/java/net/minecraft/server/World.java
2013-07-02 05:03:56 +02:00
@@ -956,6 +956,23 @@ public abstract class World implements IBlockAccess {
2013-03-22 23:48:22 +01:00
// Not all projectiles extend EntityProjectile, so check for Bukkit interface instead
event = CraftEventFactory.callProjectileLaunchEvent(entity);
}
+ // Spigot start
+ else if (entity instanceof EntityExperienceOrb) {
+ EntityExperienceOrb xp = (EntityExperienceOrb) entity;
2013-06-21 09:00:01 +02:00
+ double radius = spigotConfig.expMerge;
2013-03-22 23:48:22 +01:00
+ if (radius > 0) {
+ List<Entity> entities = this.getEntities(entity, entity.boundingBox.grow(radius, radius, radius));
+ for (Entity e : entities) {
+ if (e instanceof EntityExperienceOrb) {
+ EntityExperienceOrb loopItem = (EntityExperienceOrb) e;
+ if (!loopItem.dead) {
+ xp.value += loopItem.value;
+ loopItem.die();
+ }
+ }
+ }
+ }
+ } // Spigot end
if (event != null && (event.isCancelled() || entity.dead)) {
entity.dead = true;
2013-06-20 10:41:59 +02:00
diff --git a/src/main/java/org/spigotmc/SpigotWorldConfig.java b/src/main/java/org/spigotmc/SpigotWorldConfig.java
2013-06-22 06:16:11 +02:00
index 3ec38a1..8a6d656 100644
2013-06-20 10:41:59 +02:00
--- a/src/main/java/org/spigotmc/SpigotWorldConfig.java
+++ b/src/main/java/org/spigotmc/SpigotWorldConfig.java
2013-06-22 06:07:01 +02:00
@@ -102,4 +102,18 @@ public class SpigotWorldConfig
2013-06-21 09:14:11 +02:00
wheatModifier = getInt( "growth.wheat-modifier", 100 );
2013-06-22 06:16:11 +02:00
log( "Wheat Growth Modifier: " + wheatModifier + "%" );
2013-06-20 10:41:59 +02:00
}
+
2013-06-21 09:00:01 +02:00
+ public double itemMerge;
2013-06-20 10:41:59 +02:00
+ private void itemMerge()
+ {
2013-06-21 09:00:01 +02:00
+ itemMerge = getDouble("merge-radius.item", 2.5 );
2013-06-20 10:41:59 +02:00
+ log( "Item Merge Radius: " + itemMerge );
+ }
+
2013-06-21 09:00:01 +02:00
+ public double expMerge;
2013-06-20 10:41:59 +02:00
+ private void expMerge()
+ {
2013-06-21 09:00:01 +02:00
+ expMerge = getDouble("merge-radius.exp", 3.0 );
2013-06-20 10:41:59 +02:00
+ log( "Experience Merge Radius: " + expMerge );
+ }
}
2013-03-22 23:48:22 +01:00
--
2013-06-02 07:15:15 +02:00
1.8.1.2
2013-03-22 23:48:22 +01:00