diff --git a/src/main/java/com/gmail/nossr50/Item.java b/src/main/java/com/gmail/nossr50/Item.java index 8e002d5ec..1a960f0b2 100644 --- a/src/main/java/com/gmail/nossr50/Item.java +++ b/src/main/java/com/gmail/nossr50/Item.java @@ -1,26 +1,27 @@ /* - This file is part of mcMMO. - - mcMMO is free software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation, either version 3 of the License, or - (at your option) any later version. - - mcMMO is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with mcMMO. If not, see . + * Copyright (C) 2012 Matt 'The Yeti' Burnett & mcMMO Development + * Copyright (C) 2010-2011 'nossr50' + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . */ + package com.gmail.nossr50; import org.bukkit.Material; import org.bukkit.block.Block; import org.bukkit.entity.Player; import org.bukkit.inventory.ItemStack; -import org.bukkit.plugin.Plugin; import com.gmail.nossr50.locale.mcLocale; import com.gmail.nossr50.skills.Skills; @@ -28,54 +29,55 @@ import com.gmail.nossr50.config.LoadProperties; import com.gmail.nossr50.datatypes.PlayerProfile; public class Item { - - public static void itemchecks(Player player, Plugin plugin) - { - ItemStack inhand = player.getItemInHand(); - if(LoadProperties.chimaeraWingEnable && inhand.getTypeId() == LoadProperties.chimaeraId) - chimaerawing(player, plugin); - } - - public static void chimaerawing(Player player, Plugin plugin) - { - PlayerProfile PP = Users.getProfile(player); - ItemStack is = player.getItemInHand(); - Block block = player.getLocation().getBlock(); - int chimaeraID = LoadProperties.chimaeraId; - int itemsUsed = LoadProperties.feathersConsumedByChimaeraWing; - if(mcPermissions.getInstance().chimaeraWing(player) && is.getTypeId() == chimaeraID) - { - if(Skills.cooldownOver(player, PP.getRecentlyHurt(), 60) && is.getAmount() >= itemsUsed) - { - Block derp = player.getLocation().getBlock(); - int y = derp.getY(); - player.setItemInHand(new ItemStack(chimaeraID, is.getAmount() - itemsUsed)); - - while(y < 127) - { - y++; - if(player != null) - { - if(player.getLocation().getWorld().getBlockAt(block.getX(), y, block.getZ()).getType() != Material.AIR) - { - player.sendMessage(mcLocale.getString("Item.ChimaeraWingFail")); //$NON-NLS-1$ - player.teleport(player.getLocation().getWorld().getBlockAt(block.getX(), (y - 1), block.getZ()).getLocation()); - return; - } - } - } - - if(player.getBedSpawnLocation() != null && player.getBedSpawnLocation().getBlock().getType().equals(Material.BED_BLOCK)) - player.teleport(player.getBedSpawnLocation()); - else - player.teleport(player.getWorld().getSpawnLocation()); - - player.sendMessage(mcLocale.getString("Item.ChimaeraWingPass")); //$NON-NLS-1$ - } - else if (!Skills.cooldownOver(player, PP.getRecentlyHurt(), 60) && is.getAmount() >= itemsUsed) - player.sendMessage(mcLocale.getString("Item.InjuredWait", new Object[] {Skills.calculateTimeLeft(player, PP.getRecentlyHurt(), 60)})); //$NON-NLS-1$ - else if (is.getTypeId() == LoadProperties.chimaeraId && is.getAmount() <= itemsUsed) - player.sendMessage(mcLocale.getString("Item.NeedFeathers")); //$NON-NLS-1$ - } - } + + /** + * Check for item usage. + * + * @param player Player whose item usage to check + */ + public static void itemchecks(Player player) { + ItemStack inhand = player.getItemInHand(); + + if (LoadProperties.chimaeraWingEnable && inhand.getTypeId() == LoadProperties.chimaeraId) { + chimaerawing(player); + } + } + + private static void chimaerawing(Player player) { + PlayerProfile PP = Users.getProfile(player); + ItemStack is = player.getItemInHand(); + Block block = player.getLocation().getBlock(); + int chimaeraID = LoadProperties.chimaeraId; + int itemsUsed = LoadProperties.feathersConsumedByChimaeraWing; + int amount = is.getAmount(); + + if (mcPermissions.getInstance().chimaeraWing(player) && is.getTypeId() == chimaeraID) { + if (Skills.cooldownOver(player, PP.getRecentlyHurt(), 60) && amount >= itemsUsed) { + player.setItemInHand(new ItemStack(chimaeraID, amount - itemsUsed)); + + for (int blockY = block.getY(); blockY < 127; blockY++) { + if (player.getLocation().getWorld().getBlockAt(block.getX(), blockY, block.getZ()).getType() != Material.AIR) { + player.sendMessage(mcLocale.getString("Item.ChimaeraWingFail")); + player.teleport(player.getLocation().getWorld().getBlockAt(block.getX(), (blockY - 1), block.getZ()).getLocation()); + return; + } + } + + if (player.getBedSpawnLocation() != null && player.getBedSpawnLocation().getBlock().getType().equals(Material.BED_BLOCK)) { + player.teleport(player.getBedSpawnLocation()); + } + else { + player.teleport(player.getWorld().getSpawnLocation()); + } + + player.sendMessage(mcLocale.getString("Item.ChimaeraWingPass")); + } + else if (!Skills.cooldownOver(player, PP.getRecentlyHurt(), 60) && is.getAmount() >= itemsUsed) { + player.sendMessage(mcLocale.getString("Item.InjuredWait", new Object[] {Skills.calculateTimeLeft(player, PP.getRecentlyHurt(), 60)})); + } + else if (is.getTypeId() == LoadProperties.chimaeraId && is.getAmount() <= itemsUsed) { + player.sendMessage(mcLocale.getString("Item.NeedFeathers")); + } + } + } } diff --git a/src/main/java/com/gmail/nossr50/listeners/mcPlayerListener.java b/src/main/java/com/gmail/nossr50/listeners/mcPlayerListener.java index 888e5e506..bf8eb4ed5 100644 --- a/src/main/java/com/gmail/nossr50/listeners/mcPlayerListener.java +++ b/src/main/java/com/gmail/nossr50/listeners/mcPlayerListener.java @@ -255,9 +255,9 @@ public class mcPlayerListener implements Listener * ITEM CHECKS */ if(action == Action.RIGHT_CLICK_AIR) - Item.itemchecks(player, plugin); + Item.itemchecks(player); if(action == Action.RIGHT_CLICK_BLOCK && m.abilityBlockCheck(block)) - Item.itemchecks(player, plugin); + Item.itemchecks(player); if(player.isSneaking() && mcPermissions.getInstance().taming(player) && (action == Action.LEFT_CLICK_AIR || action == Action.LEFT_CLICK_BLOCK)) {