mirror of
https://github.com/PikaMug/Quests.git
synced 2025-01-25 17:51:35 +01:00
Merge pull request #89 from PikachuEXE/fix/NPE
! Fix NPE in player listeners
This commit is contained in:
commit
889f76d6dc
@ -47,38 +47,38 @@ public class PlayerListener implements Listener, ColorUtil {
|
|||||||
plugin = newPlugin;
|
plugin = newPlugin;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGHEST)
|
@EventHandler(priority = EventPriority.HIGHEST)
|
||||||
public void onInventoryClickEvent(InventoryClickEvent evt) {
|
public void onInventoryClickEvent(InventoryClickEvent evt) {
|
||||||
|
|
||||||
InventoryAction ac = evt.getAction();
|
InventoryAction ac = evt.getAction();
|
||||||
|
|
||||||
if(ItemUtil.isItem(evt.getCurrentItem()) && ItemUtil.isJournal(evt.getCurrentItem())) {
|
if(ItemUtil.isItem(evt.getCurrentItem()) && ItemUtil.isJournal(evt.getCurrentItem())) {
|
||||||
|
|
||||||
if(ac.equals(InventoryAction.MOVE_TO_OTHER_INVENTORY)
|
if(ac.equals(InventoryAction.MOVE_TO_OTHER_INVENTORY)
|
||||||
|| ac.equals(InventoryAction.DROP_ALL_SLOT)
|
|| ac.equals(InventoryAction.DROP_ALL_SLOT)
|
||||||
|| ac.equals(InventoryAction.DROP_ONE_SLOT)) {
|
|| ac.equals(InventoryAction.DROP_ONE_SLOT)) {
|
||||||
|
|
||||||
evt.setCancelled(true);
|
evt.setCancelled(true);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if(ItemUtil.isItem(evt.getCurrentItem()) && ItemUtil.isJournal(evt.getCursor())) {
|
} else if(ItemUtil.isItem(evt.getCurrentItem()) && ItemUtil.isJournal(evt.getCursor())) {
|
||||||
|
|
||||||
if(ac.equals(InventoryAction.MOVE_TO_OTHER_INVENTORY)
|
if(ac.equals(InventoryAction.MOVE_TO_OTHER_INVENTORY)
|
||||||
|| ac.equals(InventoryAction.DROP_ALL_CURSOR)
|
|| ac.equals(InventoryAction.DROP_ALL_CURSOR)
|
||||||
|| ac.equals(InventoryAction.DROP_ONE_CURSOR)) {
|
|| ac.equals(InventoryAction.DROP_ONE_CURSOR)) {
|
||||||
|
|
||||||
evt.setCancelled(true);
|
evt.setCancelled(true);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(ItemUtil.isItem(evt.getCurrentItem()) && ItemUtil.isJournal(evt.getCurrentItem()) || ItemUtil.isItem(evt.getCursor()) && ItemUtil.isJournal(evt.getCursor())) {
|
if(ItemUtil.isItem(evt.getCurrentItem()) && ItemUtil.isJournal(evt.getCurrentItem()) || ItemUtil.isItem(evt.getCursor()) && ItemUtil.isJournal(evt.getCursor())) {
|
||||||
|
|
||||||
int upper = evt.getView().getTopInventory().getSize();
|
int upper = evt.getView().getTopInventory().getSize();
|
||||||
if(evt.getView().getTopInventory().getType().equals(InventoryType.CRAFTING))
|
if(evt.getView().getTopInventory().getType().equals(InventoryType.CRAFTING))
|
||||||
upper += 4;
|
upper += 4;
|
||||||
@ -89,9 +89,9 @@ public class PlayerListener implements Listener, ColorUtil {
|
|||||||
evt.setCancelled(true);
|
evt.setCancelled(true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Quester quester = plugin.getQuester(evt.getWhoClicked().getUniqueId());
|
Quester quester = plugin.getQuester(evt.getWhoClicked().getUniqueId());
|
||||||
Player player = (Player) evt.getWhoClicked();
|
Player player = (Player) evt.getWhoClicked();
|
||||||
|
|
||||||
@ -176,42 +176,42 @@ public class PlayerListener implements Listener, ColorUtil {
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGHEST)
|
@EventHandler(priority = EventPriority.HIGHEST)
|
||||||
public void onInventoryDragEvent(InventoryDragEvent evt) {
|
public void onInventoryDragEvent(InventoryDragEvent evt) {
|
||||||
|
|
||||||
if(ItemUtil.isItem(evt.getOldCursor()) && ItemUtil.isJournal(evt.getOldCursor()) || ItemUtil.isItem(evt.getCursor()) && ItemUtil.isJournal(evt.getCursor())) {
|
if(ItemUtil.isItem(evt.getOldCursor()) && ItemUtil.isJournal(evt.getOldCursor()) || ItemUtil.isItem(evt.getCursor()) && ItemUtil.isJournal(evt.getCursor())) {
|
||||||
|
|
||||||
int upper = evt.getView().getTopInventory().getSize();
|
int upper = evt.getView().getTopInventory().getSize();
|
||||||
if(evt.getView().getTopInventory().getType().equals(InventoryType.CRAFTING))
|
if(evt.getView().getTopInventory().getType().equals(InventoryType.CRAFTING))
|
||||||
upper += 4;
|
upper += 4;
|
||||||
int lower = evt.getView().getBottomInventory().getSize();
|
int lower = evt.getView().getBottomInventory().getSize();
|
||||||
|
|
||||||
for(int relative : evt.getRawSlots()) {
|
for(int relative : evt.getRawSlots()) {
|
||||||
|
|
||||||
relative -= upper;
|
relative -= upper;
|
||||||
|
|
||||||
if(relative < 0 || relative >= (lower)) {
|
if(relative < 0 || relative >= (lower)) {
|
||||||
evt.setCancelled(true);
|
evt.setCancelled(true);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void onPlayerDropItem(PlayerDropItemEvent evt) {
|
public void onPlayerDropItem(PlayerDropItemEvent evt) {
|
||||||
|
|
||||||
if(ItemUtil.isJournal(evt.getItemDrop().getItemStack()))
|
if(ItemUtil.isJournal(evt.getItemDrop().getItemStack()))
|
||||||
evt.setCancelled(true);
|
evt.setCancelled(true);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void onPlayerInteract(PlayerInteractEvent evt) {
|
public void onPlayerInteract(PlayerInteractEvent evt) {
|
||||||
|
|
||||||
@ -379,17 +379,21 @@ public class PlayerListener implements Listener, ColorUtil {
|
|||||||
if (quester.currentQuests.isEmpty() == false) {
|
if (quester.currentQuests.isEmpty() == false) {
|
||||||
|
|
||||||
for (Quest quest : quester.currentQuests.keySet()) {
|
for (Quest quest : quester.currentQuests.keySet()) {
|
||||||
|
Stage currentStage = quester.getCurrentStage(quest);
|
||||||
if (quester.getCurrentStage(quest).chatEvents.isEmpty() == false) {
|
if (currentStage == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (currentStage.chatEvents.isEmpty() == false) {
|
||||||
|
|
||||||
String chat = evt.getMessage();
|
String chat = evt.getMessage();
|
||||||
for (String s : quester.getCurrentStage(quest).chatEvents.keySet()) {
|
for (String s : currentStage.chatEvents.keySet()) {
|
||||||
|
|
||||||
if (s.equalsIgnoreCase(chat)) {
|
if (s.equalsIgnoreCase(chat)) {
|
||||||
|
|
||||||
if (quester.getQuestData(quest).eventFired.get(s) == null || quester.getQuestData(quest).eventFired.get(s) == false) {
|
if (quester.getQuestData(quest).eventFired.get(s) == null || quester.getQuestData(quest).eventFired.get(s) == false) {
|
||||||
|
|
||||||
quester.getCurrentStage(quest).chatEvents.get(s).fire(quester, quest);
|
currentStage.chatEvents.get(s).fire(quester, quest);
|
||||||
quester.getQuestData(quest).eventFired.put(s, true);
|
quester.getQuestData(quest).eventFired.put(s, true);
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -691,7 +695,7 @@ public class PlayerListener implements Listener, ColorUtil {
|
|||||||
if (damager != null) {
|
if (damager != null) {
|
||||||
|
|
||||||
if (damager instanceof Projectile) {
|
if (damager instanceof Projectile) {
|
||||||
|
|
||||||
if(evt.getEntity().getLastDamageCause().getEntity() instanceof Player) {
|
if(evt.getEntity().getLastDamageCause().getEntity() instanceof Player) {
|
||||||
|
|
||||||
Player player = (Player) evt.getEntity().getLastDamageCause().getEntity();
|
Player player = (Player) evt.getEntity().getLastDamageCause().getEntity();
|
||||||
@ -767,7 +771,7 @@ public class PlayerListener implements Listener, ColorUtil {
|
|||||||
Quester quester = plugin.getQuester(player.getUniqueId());
|
Quester quester = plugin.getQuester(player.getUniqueId());
|
||||||
|
|
||||||
for (Quest quest : quester.currentQuests.keySet()) {
|
for (Quest quest : quester.currentQuests.keySet()) {
|
||||||
|
|
||||||
if (quester.getCurrentStage(quest).deathEvent != null) {
|
if (quester.getCurrentStage(quest).deathEvent != null) {
|
||||||
quester.getCurrentStage(quest).deathEvent.fire(quester, quest);
|
quester.getCurrentStage(quest).deathEvent.fire(quester, quest);
|
||||||
}
|
}
|
||||||
@ -775,18 +779,18 @@ public class PlayerListener implements Listener, ColorUtil {
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ItemStack found = null;
|
ItemStack found = null;
|
||||||
|
|
||||||
for(ItemStack stack : evt.getDrops()) {
|
for(ItemStack stack : evt.getDrops()) {
|
||||||
|
|
||||||
if(ItemUtil.isJournal(stack)) {
|
if(ItemUtil.isJournal(stack)) {
|
||||||
found = stack;
|
found = stack;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(found != null) {
|
if(found != null) {
|
||||||
Quester quester = plugin.getQuester(player.getUniqueId());
|
Quester quester = plugin.getQuester(player.getUniqueId());
|
||||||
evt.getDrops().remove(found);
|
evt.getDrops().remove(found);
|
||||||
@ -849,7 +853,7 @@ public class PlayerListener implements Listener, ColorUtil {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (Quest quest : quester.currentQuests.keySet()) {
|
for (Quest quest : quester.currentQuests.keySet()) {
|
||||||
|
|
||||||
if (quester.getCurrentStage(quest).delay > -1) {
|
if (quester.getCurrentStage(quest).delay > -1) {
|
||||||
|
|
||||||
quester.startStageTimer(quest);
|
quester.startStageTimer(quest);
|
||||||
@ -857,7 +861,7 @@ public class PlayerListener implements Listener, ColorUtil {
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(quester.hasJournal)
|
if(quester.hasJournal)
|
||||||
quester.updateJournal();
|
quester.updateJournal();
|
||||||
|
|
||||||
@ -873,13 +877,17 @@ public class PlayerListener implements Listener, ColorUtil {
|
|||||||
Quester quester = plugin.getQuester(evt.getPlayer().getUniqueId());
|
Quester quester = plugin.getQuester(evt.getPlayer().getUniqueId());
|
||||||
|
|
||||||
for (Quest quest : quester.currentQuests.keySet()) {
|
for (Quest quest : quester.currentQuests.keySet()) {
|
||||||
|
Stage currentStage = quester.getCurrentStage(quest);
|
||||||
if (quester.getCurrentStage(quest).delay > -1) {
|
if (currentStage == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (currentStage.delay > -1) {
|
||||||
quester.stopStageTimer(quest);
|
quester.stopStageTimer(quest);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (quester.getCurrentStage(quest).disconnectEvent != null) {
|
if (currentStage.disconnectEvent != null) {
|
||||||
quester.getCurrentStage(quest).disconnectEvent.fire(quester, quest);
|
currentStage.disconnectEvent.fire(quester, quest);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -903,7 +911,7 @@ public class PlayerListener implements Listener, ColorUtil {
|
|||||||
if (evt.getFrom().getBlock().equals(evt.getTo().getBlock())) {
|
if (evt.getFrom().getBlock().equals(evt.getTo().getBlock())) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (plugin.checkQuester(evt.getPlayer().getUniqueId()) == false) {
|
if (plugin.checkQuester(evt.getPlayer().getUniqueId()) == false) {
|
||||||
|
|
||||||
boolean isPlayer = true;
|
boolean isPlayer = true;
|
||||||
|
Loading…
Reference in New Issue
Block a user