Merge pull request #89 from PikachuEXE/fix/NPE

! Fix NPE in player listeners
This commit is contained in:
FlyingPikachu 2015-04-16 15:23:19 -04:00
commit 889f76d6dc

View File

@ -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;