2017-12-19 22:05:16 -05:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Tue, 19 Dec 2017 22:02:53 -0500
|
|
|
|
Subject: [PATCH] PlayerPickupExperienceEvent
|
|
|
|
|
|
|
|
Allows plugins to cancel a player picking up an experience orb
|
|
|
|
|
2021-03-16 00:19:45 -07:00
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/EntityExperienceOrb.java b/src/main/java/net/minecraft/world/entity/EntityExperienceOrb.java
|
2020-05-06 05:48:49 -04:00
|
|
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
2021-03-16 00:19:45 -07:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/EntityExperienceOrb.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/EntityExperienceOrb.java
|
2021-03-16 16:50:45 +01:00
|
|
|
@@ -0,0 +0,0 @@ import net.minecraft.core.BlockPosition;
|
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
|
|
|
import net.minecraft.network.protocol.Packet;
|
|
|
|
import net.minecraft.network.protocol.game.PacketPlayOutSpawnEntityExperienceOrb;
|
|
|
|
+import net.minecraft.server.level.EntityPlayer;
|
|
|
|
import net.minecraft.sounds.SoundEffects;
|
|
|
|
import net.minecraft.tags.Tag;
|
|
|
|
import net.minecraft.tags.TagsFluid;
|
2017-12-19 22:05:16 -05:00
|
|
|
@@ -0,0 +0,0 @@ public class EntityExperienceOrb extends Entity {
|
2019-04-27 19:23:53 -04:00
|
|
|
@Override
|
|
|
|
public void pickup(EntityHuman entityhuman) {
|
2017-12-19 22:05:16 -05:00
|
|
|
if (!this.world.isClientSide) {
|
2020-08-24 22:22:08 -04:00
|
|
|
- if (this.d == 0 && entityhuman.bu == 0) {
|
|
|
|
+ if (this.d == 0 && entityhuman.bu == 0 && new com.destroystokyo.paper.event.player.PlayerPickupExperienceEvent(((EntityPlayer) entityhuman).getBukkitEntity(), (org.bukkit.entity.ExperienceOrb) this.getBukkitEntity()).callEvent()) { // Paper
|
|
|
|
entityhuman.bu = 2;
|
2017-12-19 22:05:16 -05:00
|
|
|
entityhuman.receive(this, 1);
|
2020-06-25 06:11:48 -07:00
|
|
|
Entry<EnumItemSlot, ItemStack> entry = EnchantmentManager.a(Enchantments.MENDING, (EntityLiving) entityhuman, ItemStack::f);
|