mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-19 14:51:27 +01:00
Add BeaconEffectEvent
This commit is contained in:
parent
c8f3b4ba4f
commit
a8b69d72c7
73
Spigot-API-Patches/Add-BeaconEffectEvent.patch
Normal file
73
Spigot-API-Patches/Add-BeaconEffectEvent.patch
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Byteflux <byte@byteflux.net>
|
||||||
|
Date: Thu, 23 Jul 2015 11:45:20 -0700
|
||||||
|
Subject: [PATCH] Add BeaconEffectEvent
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/org/github/paperspigot/event/block/BeaconEffectEvent.java b/src/main/java/org/github/paperspigot/event/block/BeaconEffectEvent.java
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/src/main/java/org/github/paperspigot/event/block/BeaconEffectEvent.java
|
||||||
|
@@ -0,0 +0,0 @@
|
||||||
|
+package org.github.paperspigot.event.block;
|
||||||
|
+
|
||||||
|
+import org.bukkit.block.Block;
|
||||||
|
+import org.bukkit.entity.Player;
|
||||||
|
+import org.bukkit.event.Cancellable;
|
||||||
|
+import org.bukkit.event.HandlerList;
|
||||||
|
+import org.bukkit.event.block.BlockEvent;
|
||||||
|
+import org.bukkit.potion.PotionEffect;
|
||||||
|
+
|
||||||
|
+public class BeaconEffectEvent extends BlockEvent implements Cancellable {
|
||||||
|
+ private static final HandlerList handlers = new HandlerList();
|
||||||
|
+ private boolean cancelled;
|
||||||
|
+ private PotionEffect effect;
|
||||||
|
+ private Player player;
|
||||||
|
+ private boolean primary;
|
||||||
|
+
|
||||||
|
+ public BeaconEffectEvent(Block block, PotionEffect effect, Player player, boolean primary) {
|
||||||
|
+ super(block);
|
||||||
|
+ this.effect = effect;
|
||||||
|
+ this.player = player;
|
||||||
|
+ this.primary = primary;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public boolean isCancelled() {
|
||||||
|
+ return cancelled;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public void setCancelled(boolean cancelled) {
|
||||||
|
+ this.cancelled = cancelled;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public PotionEffect getEffect() {
|
||||||
|
+ return effect;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public void setEffect(PotionEffect effect) {
|
||||||
|
+ this.effect = effect;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public Player getPlayer() {
|
||||||
|
+ return player;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public boolean isPrimary() {
|
||||||
|
+ return primary;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public HandlerList getHandlers() {
|
||||||
|
+ return handlers;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public static HandlerList getHandlerList() {
|
||||||
|
+ return handlers;
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
--
|
||||||
|
1.9.5.msysgit.1
|
||||||
|
|
66
Spigot-Server-Patches/Add-BeaconEffectEvent.patch
Normal file
66
Spigot-Server-Patches/Add-BeaconEffectEvent.patch
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Byteflux <byte@byteflux.net>
|
||||||
|
Date: Thu, 23 Jul 2015 12:44:06 -0700
|
||||||
|
Subject: [PATCH] Add BeaconEffectEvent
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/server/TileEntityBeacon.java b/src/main/java/net/minecraft/server/TileEntityBeacon.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/server/TileEntityBeacon.java
|
||||||
|
+++ b/src/main/java/net/minecraft/server/TileEntityBeacon.java
|
||||||
|
@@ -0,0 +0,0 @@ import org.bukkit.craftbukkit.entity.CraftHumanEntity;
|
||||||
|
import org.bukkit.entity.HumanEntity;
|
||||||
|
// CraftBukkit end
|
||||||
|
|
||||||
|
+// PaperSpigot start
|
||||||
|
+import org.bukkit.craftbukkit.event.CraftEventFactory;
|
||||||
|
+import org.bukkit.entity.Player;
|
||||||
|
+import org.bukkit.potion.PotionEffect;
|
||||||
|
+import org.bukkit.potion.PotionEffectType;
|
||||||
|
+import org.github.paperspigot.event.block.BeaconEffectEvent;
|
||||||
|
+// PaperSpigot end
|
||||||
|
+
|
||||||
|
public class TileEntityBeacon extends TileEntityContainer implements IUpdatePlayerListBox, IInventory {
|
||||||
|
|
||||||
|
public static final MobEffectList[][] a = new MobEffectList[][] { { MobEffectList.FASTER_MOVEMENT, MobEffectList.FASTER_DIG}, { MobEffectList.RESISTANCE, MobEffectList.JUMP}, { MobEffectList.INCREASE_DAMAGE}, { MobEffectList.REGENERATION}};
|
||||||
|
@@ -0,0 +0,0 @@ public class TileEntityBeacon extends TileEntityContainer implements IUpdatePlay
|
||||||
|
Iterator iterator = list.iterator();
|
||||||
|
|
||||||
|
EntityHuman entityhuman;
|
||||||
|
+ // PaperSpigot start
|
||||||
|
+ org.bukkit.block.Block block = world.getWorld().getBlockAt(position.getX(), position.getY(), position.getZ());
|
||||||
|
+ PotionEffect primaryEffect = new PotionEffect(PotionEffectType.getById(this.k), 180, b0, true, true);
|
||||||
|
+ // PaperSpigot end
|
||||||
|
|
||||||
|
while (iterator.hasNext()) {
|
||||||
|
entityhuman = (EntityHuman) iterator.next();
|
||||||
|
- entityhuman.addEffect(new MobEffect(this.k, 180, b0, true, true));
|
||||||
|
+ // PaperSpigot start - BeaconEffectEvent
|
||||||
|
+ BeaconEffectEvent event = new BeaconEffectEvent(block, primaryEffect, (Player) entityhuman.getBukkitEntity(), true);
|
||||||
|
+ if (CraftEventFactory.callEvent(event).isCancelled()) continue;
|
||||||
|
+
|
||||||
|
+ PotionEffect effect = event.getEffect();
|
||||||
|
+ entityhuman.addEffect(new MobEffect(effect.getType().getId(), effect.getDuration(), effect.getAmplifier(), effect.isAmbient(), effect.hasParticles()));
|
||||||
|
+ // PaperSpigot end
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.j >= 4 && this.k != this.l && this.l > 0) {
|
||||||
|
iterator = list.iterator();
|
||||||
|
+ PotionEffect secondaryEffect = new PotionEffect(PotionEffectType.getById(this.l), 180, 0, true, true); // PaperSpigot
|
||||||
|
|
||||||
|
while (iterator.hasNext()) {
|
||||||
|
entityhuman = (EntityHuman) iterator.next();
|
||||||
|
- entityhuman.addEffect(new MobEffect(this.l, 180, 0, true, true));
|
||||||
|
+ // PaperSpigot start - BeaconEffectEvent
|
||||||
|
+ BeaconEffectEvent event = new BeaconEffectEvent(block, secondaryEffect, (Player) entityhuman.getBukkitEntity(), false);
|
||||||
|
+ if (CraftEventFactory.callEvent(event).isCancelled()) continue;
|
||||||
|
+
|
||||||
|
+ PotionEffect effect = event.getEffect();
|
||||||
|
+ entityhuman.addEffect(new MobEffect(effect.getType().getId(), effect.getDuration(), effect.getAmplifier(), effect.isAmbient(), effect.hasParticles()));
|
||||||
|
+ // PaperSpigot end
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
--
|
||||||
|
1.9.5.msysgit.1
|
||||||
|
|
Loading…
Reference in New Issue
Block a user