From 301914d94bcf61889ed9705ef355c2f2fc9fb2a4 Mon Sep 17 00:00:00 2001 From: GJ Date: Sat, 23 Feb 2013 15:03:39 -0500 Subject: [PATCH] Fix ClassCastException with trying to use Woodcutting on Mushrooms. --- .../skills/woodcutting/TreeFeller.java | 39 ++++++++----------- .../skills/woodcutting/Woodcutting.java | 7 +++- 2 files changed, 22 insertions(+), 24 deletions(-) diff --git a/src/main/java/com/gmail/nossr50/skills/woodcutting/TreeFeller.java b/src/main/java/com/gmail/nossr50/skills/woodcutting/TreeFeller.java index 4f3abeb1d..9c767f705 100644 --- a/src/main/java/com/gmail/nossr50/skills/woodcutting/TreeFeller.java +++ b/src/main/java/com/gmail/nossr50/skills/woodcutting/TreeFeller.java @@ -177,22 +177,14 @@ public final class TreeFeller { Material material = blockState.getType(); - switch (material) { - case HUGE_MUSHROOM_1: - case HUGE_MUSHROOM_2: + if (material == Material.HUGE_MUSHROOM_1 || material == Material.HUGE_MUSHROOM_2) { xp += Woodcutting.getExperienceFromLog(blockState, ExperienceGainMethod.TREE_FELLER); for (ItemStack drop : blockState.getBlock().getDrops()) { Misc.dropItem(blockState.getLocation(), drop); } - - break; - - default: - break; } - - if (ModChecks.isCustomLogBlock(blockState)) { + else if (ModChecks.isCustomLogBlock(blockState)) { Woodcutting.checkForDoubleDrop(player, blockState); CustomBlock customBlock = ModChecks.getCustomBlock(blockState); @@ -211,21 +203,22 @@ public final class TreeFeller { else if (ModChecks.isCustomLeafBlock(blockState)) { Misc.randomDropItem(blockState.getLocation(), ModChecks.getCustomBlock(blockState).getItemDrop(), 10); } + else { + Tree tree = (Tree) blockState.getData(); + switch (material) { + case LOG: + Woodcutting.checkForDoubleDrop(player, blockState); + xp += Woodcutting.getExperienceFromLog(blockState, ExperienceGainMethod.TREE_FELLER); + Misc.dropItem(blockState.getLocation(), new ItemStack(Material.LOG, 1, tree.getSpecies().getData())); + break; - Tree tree = (Tree) blockState.getData(); - switch (material) { - case LOG: - Woodcutting.checkForDoubleDrop(player, blockState); - xp += Woodcutting.getExperienceFromLog(blockState, ExperienceGainMethod.TREE_FELLER); - Misc.dropItem(blockState.getLocation(), new ItemStack(Material.LOG, 1, tree.getSpecies().getData())); - break; + case LEAVES: + Misc.randomDropItem(blockState.getLocation(), new ItemStack(Material.SAPLING, 1, tree.getSpecies().getData()), 10); + break; - case LEAVES: - Misc.randomDropItem(blockState.getLocation(), new ItemStack(Material.SAPLING, 1, tree.getSpecies().getData()), 10); - break; - - default: - break; + default: + break; + } } blockState.setRawData((byte) 0x0); diff --git a/src/main/java/com/gmail/nossr50/skills/woodcutting/Woodcutting.java b/src/main/java/com/gmail/nossr50/skills/woodcutting/Woodcutting.java index 5c1f0e788..d1d834c5b 100644 --- a/src/main/java/com/gmail/nossr50/skills/woodcutting/Woodcutting.java +++ b/src/main/java/com/gmail/nossr50/skills/woodcutting/Woodcutting.java @@ -1,6 +1,7 @@ package com.gmail.nossr50.skills.woodcutting; import org.bukkit.Location; +import org.bukkit.Material; import org.bukkit.Sound; import org.bukkit.block.BlockState; import org.bukkit.entity.Player; @@ -61,7 +62,11 @@ public final class Woodcutting { int xp = getExperienceFromLog(blockState, ExperienceGainMethod.DEFAULT); if (Permissions.doubleDrops(player, SkillType.WOODCUTTING)) { - checkForDoubleDrop(player, blockState); + Material blockType = blockState.getType(); + + if (blockType != Material.HUGE_MUSHROOM_1 && blockType != Material.HUGE_MUSHROOM_2) { + checkForDoubleDrop(player, blockState); + } } Users.getPlayer(player).beginXpGain(SkillType.WOODCUTTING, xp);