mirror of
https://github.com/Creators-of-Create/Create.git
synced 2024-12-16 06:23:42 +01:00
Fix deployer beehive crash #2
This commit is contained in:
parent
0a4aaaf81e
commit
f85894b232
1 changed files with 51 additions and 1 deletions
|
@ -6,7 +6,16 @@ import static net.minecraftforge.eventbus.api.Event.Result.DENY;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import net.minecraft.advancements.CriteriaTriggers;
|
||||||
import net.minecraft.block.BeehiveBlock;
|
import net.minecraft.block.BeehiveBlock;
|
||||||
|
import net.minecraft.block.Block;
|
||||||
|
import net.minecraft.enchantment.EnchantmentHelper;
|
||||||
|
import net.minecraft.enchantment.Enchantments;
|
||||||
|
import net.minecraft.entity.player.ServerPlayerEntity;
|
||||||
|
import net.minecraft.server.management.PlayerInteractionManager;
|
||||||
|
import net.minecraft.stats.Stats;
|
||||||
|
import net.minecraft.tileentity.BeehiveTileEntity;
|
||||||
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import org.apache.commons.lang3.tuple.Pair;
|
import org.apache.commons.lang3.tuple.Pair;
|
||||||
|
|
||||||
import com.google.common.collect.Multimap;
|
import com.google.common.collect.Multimap;
|
||||||
|
@ -206,7 +215,7 @@ public class DeployerHandler {
|
||||||
progress += before;
|
progress += before;
|
||||||
|
|
||||||
if (progress >= 1) {
|
if (progress >= 1) {
|
||||||
player.interactionManager.tryHarvestBlock(clickedPos);
|
safeTryHarvestBlock(player.interactionManager, clickedPos);
|
||||||
world.sendBlockBreakProgress(player.getEntityId(), clickedPos, -1);
|
world.sendBlockBreakProgress(player.getEntityId(), clickedPos, -1);
|
||||||
player.blockBreakingProgress = null;
|
player.blockBreakingProgress = null;
|
||||||
return;
|
return;
|
||||||
|
@ -293,4 +302,45 @@ public class DeployerHandler {
|
||||||
player.resetActiveHand();
|
player.resetActiveHand();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static boolean safeTryHarvestBlock(PlayerInteractionManager interactionManager, BlockPos clickedPos) {
|
||||||
|
BlockState state = interactionManager.world.getBlockState(clickedPos);
|
||||||
|
if(!(state.getBlock() instanceof BeehiveBlock))
|
||||||
|
return interactionManager.tryHarvestBlock(clickedPos);
|
||||||
|
else {
|
||||||
|
harvestBeehive(interactionManager, state, clickedPos);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void harvestBeehive(PlayerInteractionManager interactionManager, BlockState state, BlockPos clickedPos) {
|
||||||
|
// Modified code from PlayerInteractionManager, Block and BeehiveBlock to handle deployers breaking beehives without crash.
|
||||||
|
ItemStack itemstack = interactionManager.player.getHeldItemMainhand();
|
||||||
|
ItemStack itemstack1 = itemstack.copy();
|
||||||
|
|
||||||
|
boolean flag1 = state.canHarvestBlock(interactionManager.world, clickedPos, interactionManager.player);
|
||||||
|
itemstack.onBlockDestroyed(interactionManager.world, state, clickedPos, interactionManager.player);
|
||||||
|
if (itemstack.isEmpty() && !itemstack1.isEmpty())
|
||||||
|
net.minecraftforge.event.ForgeEventFactory.onPlayerDestroyItem(interactionManager.player, itemstack1, Hand.MAIN_HAND);
|
||||||
|
|
||||||
|
boolean flag = state.removedByPlayer(interactionManager.world, clickedPos, interactionManager.player, flag1, interactionManager.world.getFluidState(clickedPos));
|
||||||
|
if (flag)
|
||||||
|
state.getBlock().onPlayerDestroy(interactionManager.world, clickedPos, state);
|
||||||
|
|
||||||
|
if (flag && flag1) {
|
||||||
|
interactionManager.player.addStat(Stats.BLOCK_MINED.get(state.getBlock()));
|
||||||
|
interactionManager.player.addExhaustion(0.005F);
|
||||||
|
TileEntity te = interactionManager.world.getTileEntity(clickedPos);
|
||||||
|
ItemStack heldItem = interactionManager.player.getHeldItemMainhand();
|
||||||
|
Block.spawnDrops(state, interactionManager.world, clickedPos, te, interactionManager.player, heldItem);
|
||||||
|
|
||||||
|
if (!interactionManager.world.isRemote && te instanceof BeehiveTileEntity) {
|
||||||
|
BeehiveTileEntity beehivetileentity = (BeehiveTileEntity)te;
|
||||||
|
if (EnchantmentHelper.getEnchantmentLevel(Enchantments.SILK_TOUCH, heldItem) == 0) {
|
||||||
|
interactionManager.world.updateComparatorOutputLevel(clickedPos, state.getBlock());
|
||||||
|
}
|
||||||
|
|
||||||
|
CriteriaTriggers.BEE_NEST_DESTROYED.test((ServerPlayerEntity)interactionManager.player, state.getBlock(), heldItem, beehivetileentity.getBeeCount());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue