geforkt von Mirrors/Paper
333 Zeilen
21 KiB
Diff
333 Zeilen
21 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Aikar <aikar@aikar.co>
|
||
|
Date: Tue, 19 Dec 2017 16:31:46 -0500
|
||
|
Subject: [PATCH] ExperienceOrbs API for Reason/Source/Triggering player
|
||
|
|
||
|
Adds lots of information about why this orb exists.
|
||
|
|
||
|
Replaces isFromBottle() with logic that persists entity reloads too.
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/server/level/ServerPlayerGameMode.java b/src/main/java/net/minecraft/server/level/ServerPlayerGameMode.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/server/level/ServerPlayerGameMode.java
|
||
|
+++ b/src/main/java/net/minecraft/server/level/ServerPlayerGameMode.java
|
||
|
@@ -0,0 +0,0 @@ public class ServerPlayerGameMode {
|
||
|
|
||
|
// Drop event experience
|
||
|
if (flag && event != null) {
|
||
|
- iblockdata.getBlock().popExperience(this.level, pos, event.getExpToDrop());
|
||
|
+ iblockdata.getBlock().dropExperience(this.level, pos, event.getExpToDrop(), this.player); // Paper
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
diff --git a/src/main/java/net/minecraft/world/entity/ExperienceOrb.java b/src/main/java/net/minecraft/world/entity/ExperienceOrb.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/entity/ExperienceOrb.java
|
||
|
+++ b/src/main/java/net/minecraft/world/entity/ExperienceOrb.java
|
||
|
@@ -0,0 +0,0 @@ public class ExperienceOrb extends Entity {
|
||
|
public int value;
|
||
|
private Player followingPlayer;
|
||
|
private int followingTime;
|
||
|
+ // Paper start
|
||
|
+ public java.util.UUID sourceEntityId;
|
||
|
+ public java.util.UUID triggerEntityId;
|
||
|
+ public org.bukkit.entity.ExperienceOrb.SpawnReason spawnReason = org.bukkit.entity.ExperienceOrb.SpawnReason.UNKNOWN;
|
||
|
+
|
||
|
+ private void loadPaperNBT(CompoundTag nbttagcompound) {
|
||
|
+ if (!nbttagcompound.contains("Paper.ExpData", 10)) { // 10 = compound
|
||
|
+ return;
|
||
|
+ }
|
||
|
+ CompoundTag comp = nbttagcompound.getCompound("Paper.ExpData");
|
||
|
+ if (comp.hasUUID("source")) {
|
||
|
+ this.sourceEntityId = comp.getUUID("source");
|
||
|
+ }
|
||
|
+ if (comp.hasUUID("trigger")) {
|
||
|
+ this.triggerEntityId = comp.getUUID("trigger");
|
||
|
+ }
|
||
|
+ if (comp.contains("reason")) {
|
||
|
+ String reason = comp.getString("reason");
|
||
|
+ try {
|
||
|
+ this.spawnReason = org.bukkit.entity.ExperienceOrb.SpawnReason.valueOf(reason);
|
||
|
+ } catch (Exception e) {
|
||
|
+ this.level.getCraftServer().getLogger().warning("Invalid spawnReason set for experience orb: " + e.getMessage() + " - " + reason);
|
||
|
+ }
|
||
|
+ }
|
||
|
+ }
|
||
|
+ private void savePaperNBT(CompoundTag nbttagcompound) {
|
||
|
+ CompoundTag comp = new CompoundTag();
|
||
|
+ if (this.sourceEntityId != null) {
|
||
|
+ comp.setUUID("source", this.sourceEntityId);
|
||
|
+ }
|
||
|
+ if (this.triggerEntityId != null) {
|
||
|
+ comp.setUUID("trigger", triggerEntityId);
|
||
|
+ }
|
||
|
+ if (this.spawnReason != null && this.spawnReason != org.bukkit.entity.ExperienceOrb.SpawnReason.UNKNOWN) {
|
||
|
+ comp.putString("reason", this.spawnReason.name());
|
||
|
+ }
|
||
|
+ nbttagcompound.put("Paper.ExpData", comp);
|
||
|
+ }
|
||
|
|
||
|
public ExperienceOrb(Level world, double x, double y, double z, int amount) {
|
||
|
+ this(world, x, y, z, amount, null, null);
|
||
|
+ }
|
||
|
+
|
||
|
+ public EntityExperienceOrb(Level world, double d0, double d1, double d2, int i, org.bukkit.entity.ExperienceOrb.SpawnReason reason, Entity triggerId) {
|
||
|
+ this(world, d0, d1, d2, i, reason, triggerId, null);
|
||
|
+ }
|
||
|
+
|
||
|
+ public EntityExperienceOrb(Level world, double d0, double d1, double d2, int i, org.bukkit.entity.ExperienceOrb.SpawnReason reason, Entity triggerId, Entity sourceId) {
|
||
|
this(EntityType.EXPERIENCE_ORB, world);
|
||
|
- this.setPos(x, y, z);
|
||
|
+ this.sourceEntityId = sourceId != null ? sourceId.getUUID() : null;
|
||
|
+ this.triggerEntityId = triggerId != null ? triggerId.getUUID() : null;
|
||
|
+ this.spawnReason = reason != null ? reason : org.bukkit.entity.ExperienceOrb.SpawnReason.UNKNOWN;
|
||
|
+ // Paper end
|
||
|
+ this.setPos(d0, d1, d2);
|
||
|
this.yRot = (float) (this.random.nextDouble() * 360.0D);
|
||
|
this.setDeltaMovement((this.random.nextDouble() * 0.20000000298023224D - 0.10000000149011612D) * 2.0D, this.random.nextDouble() * 0.2D * 2.0D, (this.random.nextDouble() * 0.20000000298023224D - 0.10000000149011612D) * 2.0D);
|
||
|
- this.value = amount;
|
||
|
+ this.value = i;
|
||
|
}
|
||
|
|
||
|
public ExperienceOrb(EntityType<? extends ExperienceOrb> type, Level world) {
|
||
|
@@ -0,0 +0,0 @@ public class ExperienceOrb extends Entity {
|
||
|
tag.putShort("Health", (short) this.health);
|
||
|
tag.putShort("Age", (short) this.age);
|
||
|
tag.putShort("Value", (short) this.value);
|
||
|
+ this.savePaperNBT(tag); // Paper
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
@@ -0,0 +0,0 @@ public class ExperienceOrb extends Entity {
|
||
|
this.health = tag.getShort("Health");
|
||
|
this.age = tag.getShort("Age");
|
||
|
this.value = tag.getShort("Value");
|
||
|
+ this.loadPaperNBT(tag); // Paper
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
diff --git a/src/main/java/net/minecraft/world/entity/LivingEntity.java b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
||
|
+++ b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
||
|
@@ -0,0 +0,0 @@ public abstract class LivingEntity extends Entity {
|
||
|
int j = ExperienceOrb.getExperienceValue(i);
|
||
|
|
||
|
i -= j;
|
||
|
- this.level.addFreshEntity(new ExperienceOrb(this.level, this.getX(), this.getY(), this.getZ(), j));
|
||
|
+ LivingEntity attacker = lastHurtByPlayer != null ? lastHurtByPlayer : lastHurtByMob; // Paper
|
||
|
+ this.level.addFreshEntity(new ExperienceOrb(this.level, this.getX(), this.getY(), this.getZ(), j, this instanceof ServerPlayer ? org.bukkit.entity.ExperienceOrb.SpawnReason.PLAYER_DEATH : org.bukkit.entity.ExperienceOrb.SpawnReason.ENTITY_DEATH, attacker, this)); // Paper
|
||
|
}
|
||
|
this.expToDrop = 0;
|
||
|
}
|
||
|
diff --git a/src/main/java/net/minecraft/world/entity/animal/Animal.java b/src/main/java/net/minecraft/world/entity/animal/Animal.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/entity/animal/Animal.java
|
||
|
+++ b/src/main/java/net/minecraft/world/entity/animal/Animal.java
|
||
|
@@ -0,0 +0,0 @@ public abstract class Animal extends AgableMob {
|
||
|
if (worldserver.getGameRules().getBoolean(GameRules.RULE_DOMOBLOOT)) {
|
||
|
// CraftBukkit start - use event experience
|
||
|
if (experience > 0) {
|
||
|
- worldserver.addFreshEntity(new ExperienceOrb(worldserver, this.getX(), this.getY(), this.getZ(), experience));
|
||
|
+ worldserver.addFreshEntity(new ExperienceOrb(worldserver, this.getX(), this.getY(), this.getZ(), experience, org.bukkit.entity.ExperienceOrb.SpawnReason.BREED, entityplayer, entityageable)); // Paper
|
||
|
}
|
||
|
// CraftBukkit end
|
||
|
}
|
||
|
diff --git a/src/main/java/net/minecraft/world/entity/animal/Fox.java b/src/main/java/net/minecraft/world/entity/animal/Fox.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/entity/animal/Fox.java
|
||
|
+++ b/src/main/java/net/minecraft/world/entity/animal/Fox.java
|
||
|
@@ -0,0 +0,0 @@ public class Fox extends Animal {
|
||
|
if (this.level.getGameRules().getBoolean(GameRules.RULE_DOMOBLOOT)) {
|
||
|
// CraftBukkit start - use event experience
|
||
|
if (experience > 0) {
|
||
|
- this.level.addFreshEntity(new ExperienceOrb(this.level, this.animal.getX(), this.animal.getY(), this.animal.getZ(), experience));
|
||
|
+ this.level.addFreshEntity(new ExperienceOrb(this.level, this.animal.getX(), this.animal.getY(), this.animal.getZ(), experience, org.bukkit.entity.ExperienceOrb.SpawnReason.BREED, entityplayer, entityfox)); // Paper
|
||
|
}
|
||
|
// CraftBukkit end
|
||
|
}
|
||
|
diff --git a/src/main/java/net/minecraft/world/entity/animal/Turtle.java b/src/main/java/net/minecraft/world/entity/animal/Turtle.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/entity/animal/Turtle.java
|
||
|
+++ b/src/main/java/net/minecraft/world/entity/animal/Turtle.java
|
||
|
@@ -0,0 +0,0 @@ public class Turtle extends Animal {
|
||
|
Random random = this.animal.getRandom();
|
||
|
|
||
|
if (this.level.getGameRules().getBoolean(GameRules.RULE_DOMOBLOOT)) {
|
||
|
- this.level.addFreshEntity(new ExperienceOrb(this.level, this.animal.getX(), this.animal.getY(), this.animal.getZ(), random.nextInt(7) + 1));
|
||
|
+ this.level.addFreshEntity(new ExperienceOrb(this.level, this.animal.getX(), this.animal.getY(), this.animal.getZ(), random.nextInt(7) + 1, org.bukkit.entity.ExperienceOrb.SpawnReason.BREED, entityplayer)); // Paper;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
diff --git a/src/main/java/net/minecraft/world/entity/boss/enderdragon/EnderDragon.java b/src/main/java/net/minecraft/world/entity/boss/enderdragon/EnderDragon.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/entity/boss/enderdragon/EnderDragon.java
|
||
|
+++ b/src/main/java/net/minecraft/world/entity/boss/enderdragon/EnderDragon.java
|
||
|
@@ -0,0 +0,0 @@ public class EnderDragon extends Mob implements Enemy {
|
||
|
int j = ExperienceOrb.getExperienceValue(amount);
|
||
|
|
||
|
amount -= j;
|
||
|
- this.level.addFreshEntity(new ExperienceOrb(this.level, this.getX(), this.getY(), this.getZ(), j));
|
||
|
+ this.level.addFreshEntity(new ExperienceOrb(this.level, this.getX(), this.getY(), this.getZ(), j, org.bukkit.entity.ExperienceOrb.SpawnReason.ENTITY_DEATH, this.lastHurtByPlayer, this)); // Paper
|
||
|
}
|
||
|
|
||
|
}
|
||
|
diff --git a/src/main/java/net/minecraft/world/entity/npc/Villager.java b/src/main/java/net/minecraft/world/entity/npc/Villager.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/entity/npc/Villager.java
|
||
|
+++ b/src/main/java/net/minecraft/world/entity/npc/Villager.java
|
||
|
@@ -0,0 +0,0 @@ public class Villager extends AbstractVillager implements ReputationEventHandler
|
||
|
}
|
||
|
|
||
|
if (offer.shouldRewardExp()) {
|
||
|
- this.level.addFreshEntity(new ExperienceOrb(this.level, this.getX(), this.getY() + 0.5D, this.getZ(), i));
|
||
|
+ this.level.addFreshEntity(new ExperienceOrb(this.level, this.getX(), this.getY() + 0.5D, this.getZ(), i, org.bukkit.entity.ExperienceOrb.SpawnReason.VILLAGER_TRADE, this.getTradingPlayer(), this)); // Paper
|
||
|
}
|
||
|
|
||
|
}
|
||
|
diff --git a/src/main/java/net/minecraft/world/entity/npc/WanderingTrader.java b/src/main/java/net/minecraft/world/entity/npc/WanderingTrader.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/entity/npc/WanderingTrader.java
|
||
|
+++ b/src/main/java/net/minecraft/world/entity/npc/WanderingTrader.java
|
||
|
@@ -0,0 +0,0 @@ public class WanderingTrader extends net.minecraft.world.entity.npc.AbstractVill
|
||
|
if (offer.shouldRewardExp()) {
|
||
|
int i = 3 + this.random.nextInt(4);
|
||
|
|
||
|
- this.level.addFreshEntity(new ExperienceOrb(this.level, this.getX(), this.getY() + 0.5D, this.getZ(), i));
|
||
|
+ this.level.addFreshEntity(new ExperienceOrb(this.level, this.getX(), this.getY() + 0.5D, this.getZ(), i, org.bukkit.entity.ExperienceOrb.SpawnReason.VILLAGER_TRADE, this.getTradingPlayer(), this)); // Paper
|
||
|
}
|
||
|
|
||
|
}
|
||
|
diff --git a/src/main/java/net/minecraft/world/entity/projectile/FishingHook.java b/src/main/java/net/minecraft/world/entity/projectile/FishingHook.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/entity/projectile/FishingHook.java
|
||
|
+++ b/src/main/java/net/minecraft/world/entity/projectile/FishingHook.java
|
||
|
@@ -0,0 +0,0 @@ public class FishingHook extends Projectile {
|
||
|
this.level.addFreshEntity(entityitem);
|
||
|
// CraftBukkit start - this.random.nextInt(6) + 1 -> playerFishEvent.getExpToDrop()
|
||
|
if (playerFishEvent.getExpToDrop() > 0) {
|
||
|
- entityhuman.level.addFreshEntity(new ExperienceOrb(entityhuman.level, entityhuman.getX(), entityhuman.getY() + 0.5D, entityhuman.getZ() + 0.5D, playerFishEvent.getExpToDrop()));
|
||
|
+ entityhuman.level.addFreshEntity(new ExperienceOrb(entityhuman.level, entityhuman.getX(), entityhuman.getY() + 0.5D, entityhuman.getZ() + 0.5D, playerFishEvent.getExpToDrop(), org.bukkit.entity.ExperienceOrb.SpawnReason.FISHING, this.getPlayerOwner(), this)); // Paper
|
||
|
}
|
||
|
// CraftBukkit end
|
||
|
if (itemstack1.getItem().is((Tag) ItemTags.FISHES)) {
|
||
|
diff --git a/src/main/java/net/minecraft/world/entity/projectile/ThrownExperienceBottle.java b/src/main/java/net/minecraft/world/entity/projectile/ThrownExperienceBottle.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/entity/projectile/ThrownExperienceBottle.java
|
||
|
+++ b/src/main/java/net/minecraft/world/entity/projectile/ThrownExperienceBottle.java
|
||
|
@@ -0,0 +0,0 @@ public class ThrownExperienceBottle extends ThrowableItemProjectile {
|
||
|
int j = ExperienceOrb.getExperienceValue(i);
|
||
|
|
||
|
i -= j;
|
||
|
- this.level.addFreshEntity(new ExperienceOrb(this.level, this.getX(), this.getY(), this.getZ(), j));
|
||
|
+ this.level.addFreshEntity(new ExperienceOrb(this.level, this.getX(), this.getY(), this.getZ(), j, org.bukkit.entity.ExperienceOrb.SpawnReason.EXP_BOTTLE, getOwner(), this)); // Paper
|
||
|
}
|
||
|
|
||
|
this.remove();
|
||
|
diff --git a/src/main/java/net/minecraft/world/inventory/FurnaceResultSlot.java b/src/main/java/net/minecraft/world/inventory/FurnaceResultSlot.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/inventory/FurnaceResultSlot.java
|
||
|
+++ b/src/main/java/net/minecraft/world/inventory/FurnaceResultSlot.java
|
||
|
@@ -0,0 +0,0 @@ import net.minecraft.world.level.block.entity.AbstractFurnaceBlockEntity;
|
||
|
|
||
|
public class FurnaceResultSlot extends Slot {
|
||
|
|
||
|
- private final Player player;
|
||
|
+ private final Player player; public final Player getPlayer() { return this.player; } // Paper OBFHELPER
|
||
|
private int removeCount;
|
||
|
|
||
|
public FurnaceResultSlot(Player player, Container inventory, int index, int x, int y) {
|
||
|
diff --git a/src/main/java/net/minecraft/world/inventory/GrindstoneMenu.java b/src/main/java/net/minecraft/world/inventory/GrindstoneMenu.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/inventory/GrindstoneMenu.java
|
||
|
+++ b/src/main/java/net/minecraft/world/inventory/GrindstoneMenu.java
|
||
|
@@ -0,0 +0,0 @@ public class GrindstoneMenu extends AbstractContainerMenu {
|
||
|
int k = ExperienceOrb.getExperienceValue(j);
|
||
|
|
||
|
j -= k;
|
||
|
- world.addFreshEntity(new ExperienceOrb(world, (double) blockposition.getX(), (double) blockposition.getY() + 0.5D, (double) blockposition.getZ() + 0.5D, k));
|
||
|
+ world.addFreshEntity(new ExperienceOrb(world, (double) blockposition.getX(), (double) blockposition.getY() + 0.5D, (double) blockposition.getZ() + 0.5D, k, org.bukkit.entity.ExperienceOrb.SpawnReason.GRINDSTONE, player)); // Paper
|
||
|
}
|
||
|
|
||
|
world.levelEvent(1042, blockposition, 0);
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/Block.java b/src/main/java/net/minecraft/world/level/block/Block.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/Block.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/Block.java
|
||
|
@@ -0,0 +0,0 @@ public class Block extends BlockBehaviour implements ItemLike {
|
||
|
}
|
||
|
}
|
||
|
|
||
|
- public void popExperience(ServerLevel world, BlockPos pos, int size) {
|
||
|
- if (world.getGameRules().getBoolean(GameRules.RULE_DOBLOCKDROPS)) {
|
||
|
- while (size > 0) {
|
||
|
- int j = ExperienceOrb.getExperienceValue(size);
|
||
|
+ public void dropExperience(ServerLevel worldserver, BlockPos blockposition, int i, net.minecraft.server.level.ServerPlayer player) { // Paper
|
||
|
+ if (worldserver.getGameRules().getBoolean(GameRules.RULE_DOBLOCKDROPS)) {
|
||
|
+ while (i > 0) {
|
||
|
+ int j = ExperienceOrb.getExperienceValue(i);
|
||
|
|
||
|
- size -= j;
|
||
|
- world.addFreshEntity(new ExperienceOrb(world, (double) pos.getX() + 0.5D, (double) pos.getY() + 0.5D, (double) pos.getZ() + 0.5D, j));
|
||
|
+ i -= j;
|
||
|
+ worldserver.addFreshEntity(new ExperienceOrb(worldserver, (double) blockposition.getX() + 0.5D, (double) blockposition.getY() + 0.5D, (double) blockposition.getZ() + 0.5D, j, org.bukkit.entity.ExperienceOrb.SpawnReason.BLOCK_BREAK, player)); // Paper
|
||
|
}
|
||
|
}
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/entity/AbstractFurnaceBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/AbstractFurnaceBlockEntity.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/entity/AbstractFurnaceBlockEntity.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/entity/AbstractFurnaceBlockEntity.java
|
||
|
@@ -0,0 +0,0 @@ public abstract class AbstractFurnaceBlockEntity extends BaseContainerBlockEntit
|
||
|
int k = ExperienceOrb.getExperienceValue(j);
|
||
|
|
||
|
j -= k;
|
||
|
- world.addFreshEntity(new ExperienceOrb(world, vec3d.x, vec3d.y, vec3d.z, k));
|
||
|
+ world.addFreshEntity(new ExperienceOrb(world, vec3d.x, vec3d.y, vec3d.z, k, org.bukkit.entity.ExperienceOrb.SpawnReason.FURNACE, entityhuman)); // Paper
|
||
|
}
|
||
|
|
||
|
}
|
||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
||
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
||
|
@@ -0,0 +0,0 @@ public class CraftWorld implements World {
|
||
|
} else if (TNTPrimed.class.isAssignableFrom(clazz)) {
|
||
|
entity = new PrimedTnt(world, x, y, z, null);
|
||
|
} else if (ExperienceOrb.class.isAssignableFrom(clazz)) {
|
||
|
- entity = new net.minecraft.world.entity.ExperienceOrb(world, x, y, z, 0);
|
||
|
+ entity = new net.minecraft.world.entity.ExperienceOrb(world, x, y, z, 0, org.bukkit.entity.ExperienceOrb.SpawnReason.CUSTOM, null, null); // Paper
|
||
|
} else if (LightningStrike.class.isAssignableFrom(clazz)) {
|
||
|
entity = net.minecraft.world.entity.EntityType.LIGHTNING_BOLT.create(world);
|
||
|
} else if (AreaEffectCloud.class.isAssignableFrom(clazz)) {
|
||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftExperienceOrb.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftExperienceOrb.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftExperienceOrb.java
|
||
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftExperienceOrb.java
|
||
|
@@ -0,0 +0,0 @@
|
||
|
package org.bukkit.craftbukkit.entity;
|
||
|
|
||
|
+import SpawnReason;
|
||
|
import org.bukkit.craftbukkit.CraftServer;
|
||
|
import org.bukkit.entity.EntityType;
|
||
|
import org.bukkit.entity.ExperienceOrb;
|
||
|
@@ -0,0 +0,0 @@ public class CraftExperienceOrb extends CraftEntity implements ExperienceOrb {
|
||
|
getHandle().value = value;
|
||
|
}
|
||
|
|
||
|
+ // Paper start
|
||
|
+ public java.util.UUID getTriggerEntityId() {
|
||
|
+ return getHandle().triggerEntityId;
|
||
|
+ }
|
||
|
+ public java.util.UUID getSourceEntityId() {
|
||
|
+ return getHandle().sourceEntityId;
|
||
|
+ }
|
||
|
+ public SpawnReason getSpawnReason() {
|
||
|
+ return getHandle().spawnReason;
|
||
|
+ }
|
||
|
+ // Paper end
|
||
|
+
|
||
|
@Override
|
||
|
public net.minecraft.world.entity.ExperienceOrb getHandle() {
|
||
|
return (net.minecraft.world.entity.ExperienceOrb) entity;
|