mirror of
https://github.com/Ellpeck/ActuallyAdditions.git
synced 2024-11-26 08:48:34 +01:00
made servers not crash
This commit is contained in:
parent
fee478d960
commit
04380246be
3 changed files with 99 additions and 103 deletions
|
@ -13,11 +13,19 @@ package de.ellpeck.actuallyadditions.mod.event;
|
||||||
import de.ellpeck.actuallyadditions.mod.config.values.ConfigBoolValues;
|
import de.ellpeck.actuallyadditions.mod.config.values.ConfigBoolValues;
|
||||||
import de.ellpeck.actuallyadditions.mod.data.PlayerData;
|
import de.ellpeck.actuallyadditions.mod.data.PlayerData;
|
||||||
import de.ellpeck.actuallyadditions.mod.data.WorldData;
|
import de.ellpeck.actuallyadditions.mod.data.WorldData;
|
||||||
|
import de.ellpeck.actuallyadditions.mod.inventory.ContainerBag;
|
||||||
import de.ellpeck.actuallyadditions.mod.items.InitItems;
|
import de.ellpeck.actuallyadditions.mod.items.InitItems;
|
||||||
|
import de.ellpeck.actuallyadditions.mod.items.ItemBag;
|
||||||
|
import de.ellpeck.actuallyadditions.mod.items.ItemDrill;
|
||||||
|
import de.ellpeck.actuallyadditions.mod.items.metalists.TheMiscItems;
|
||||||
import de.ellpeck.actuallyadditions.mod.misc.DungeonLoot;
|
import de.ellpeck.actuallyadditions.mod.misc.DungeonLoot;
|
||||||
import de.ellpeck.actuallyadditions.mod.network.PacketHandlerHelper;
|
import de.ellpeck.actuallyadditions.mod.network.PacketHandlerHelper;
|
||||||
|
import de.ellpeck.actuallyadditions.mod.tile.FilterSettings;
|
||||||
|
import de.ellpeck.actuallyadditions.mod.util.ItemStackHandlerCustom;
|
||||||
|
import de.ellpeck.actuallyadditions.mod.util.ItemUtil;
|
||||||
import de.ellpeck.actuallyadditions.mod.util.ModUtil;
|
import de.ellpeck.actuallyadditions.mod.util.ModUtil;
|
||||||
import de.ellpeck.actuallyadditions.mod.util.StackUtil;
|
import de.ellpeck.actuallyadditions.mod.util.StackUtil;
|
||||||
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.entity.item.EntityItem;
|
import net.minecraft.entity.item.EntityItem;
|
||||||
import net.minecraft.entity.monster.EntitySpider;
|
import net.minecraft.entity.monster.EntitySpider;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
|
@ -27,7 +35,9 @@ import net.minecraft.item.ItemStack;
|
||||||
import net.minecraftforge.common.MinecraftForge;
|
import net.minecraftforge.common.MinecraftForge;
|
||||||
import net.minecraftforge.event.entity.living.LivingDropsEvent;
|
import net.minecraftforge.event.entity.living.LivingDropsEvent;
|
||||||
import net.minecraftforge.event.entity.player.EntityItemPickupEvent;
|
import net.minecraftforge.event.entity.player.EntityItemPickupEvent;
|
||||||
|
import net.minecraftforge.event.world.BlockEvent;
|
||||||
import net.minecraftforge.event.world.WorldEvent;
|
import net.minecraftforge.event.world.WorldEvent;
|
||||||
|
import net.minecraftforge.fml.common.eventhandler.Event;
|
||||||
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
|
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
|
||||||
import net.minecraftforge.fml.common.gameevent.PlayerEvent;
|
import net.minecraftforge.fml.common.gameevent.PlayerEvent;
|
||||||
|
|
||||||
|
@ -40,6 +50,90 @@ public class CommonEvents{
|
||||||
MinecraftForge.EVENT_BUS.register(new DungeonLoot());
|
MinecraftForge.EVENT_BUS.register(new DungeonLoot());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SubscribeEvent
|
||||||
|
public void onBlockBreakEvent(BlockEvent.HarvestDropsEvent event){
|
||||||
|
IBlockState state = event.getState();
|
||||||
|
if(state != null && state.getBlock() == Blocks.MOB_SPAWNER){
|
||||||
|
event.getDrops().add(new ItemStack(InitItems.itemMisc, 1, TheMiscItems.SPAWNER_SHARD.ordinal()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SubscribeEvent
|
||||||
|
public void onItemPickup(EntityItemPickupEvent event){
|
||||||
|
if(event.isCanceled() || event.getResult() == Event.Result.ALLOW){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
EntityPlayer player = event.getEntityPlayer();
|
||||||
|
EntityItem item = event.getItem();
|
||||||
|
if(item != null && !item.isDead){
|
||||||
|
ItemStack stack = item.getEntityItem();
|
||||||
|
if(StackUtil.isValid(stack)){
|
||||||
|
for(int i = 0; i < player.inventory.getSizeInventory(); i++){
|
||||||
|
if(i != player.inventory.currentItem){
|
||||||
|
|
||||||
|
ItemStack invStack = player.inventory.getStackInSlot(i);
|
||||||
|
if(StackUtil.isValid(invStack) && invStack.getItem() instanceof ItemBag && invStack.hasTagCompound()){
|
||||||
|
if(invStack.getTagCompound().getBoolean("AutoInsert")){
|
||||||
|
boolean changed = false;
|
||||||
|
|
||||||
|
boolean isVoid = ((ItemBag)invStack.getItem()).isVoid;
|
||||||
|
ItemStackHandlerCustom inv = new ItemStackHandlerCustom(ContainerBag.getSlotAmount(isVoid));
|
||||||
|
ItemDrill.loadSlotsFromNBT(inv, invStack);
|
||||||
|
|
||||||
|
FilterSettings filter = new FilterSettings(4, false, false, false, false, 0, 0);
|
||||||
|
filter.readFromNBT(invStack.getTagCompound(), "Filter");
|
||||||
|
if(filter.check(stack)){
|
||||||
|
if(isVoid){
|
||||||
|
stack = StackUtil.setStackSize(stack, 0);
|
||||||
|
changed = true;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
for(int j = 0; j < inv.getSlots(); j++){
|
||||||
|
ItemStack bagStack = inv.getStackInSlot(j);
|
||||||
|
if(StackUtil.isValid(bagStack)){
|
||||||
|
if(ItemUtil.canBeStacked(bagStack, stack)){
|
||||||
|
int maxTransfer = Math.min(StackUtil.getStackSize(stack), stack.getMaxStackSize()-StackUtil.getStackSize(bagStack));
|
||||||
|
if(maxTransfer > 0){
|
||||||
|
inv.setStackInSlot(j, StackUtil.addStackSize(bagStack, maxTransfer));
|
||||||
|
stack = StackUtil.addStackSize(stack, -maxTransfer);
|
||||||
|
changed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
inv.setStackInSlot(j, stack.copy());
|
||||||
|
stack = StackUtil.setStackSize(stack, 0);
|
||||||
|
changed = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!StackUtil.isValid(stack)){
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(changed){
|
||||||
|
if(!isVoid){
|
||||||
|
ItemDrill.writeSlotsToNBT(inv, invStack);
|
||||||
|
}
|
||||||
|
event.setResult(Event.Result.ALLOW);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!StackUtil.isValid(stack)){
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
item.setEntityItemStack(stack);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//TODO Checking Achievements?
|
//TODO Checking Achievements?
|
||||||
/*public static void checkAchievements(ItemStack gotten, EntityPlayer player, InitAchievements.Type type){
|
/*public static void checkAchievements(ItemStack gotten, EntityPlayer player, InitAchievements.Type type){
|
||||||
if(gotten != null && player != null){
|
if(gotten != null && player != null){
|
||||||
|
|
|
@ -14,10 +14,11 @@ import de.ellpeck.actuallyadditions.mod.ActuallyAdditions;
|
||||||
import de.ellpeck.actuallyadditions.mod.inventory.ContainerBag;
|
import de.ellpeck.actuallyadditions.mod.inventory.ContainerBag;
|
||||||
import de.ellpeck.actuallyadditions.mod.inventory.GuiHandler.GuiTypes;
|
import de.ellpeck.actuallyadditions.mod.inventory.GuiHandler.GuiTypes;
|
||||||
import de.ellpeck.actuallyadditions.mod.items.base.ItemBase;
|
import de.ellpeck.actuallyadditions.mod.items.base.ItemBase;
|
||||||
import de.ellpeck.actuallyadditions.mod.tile.FilterSettings;
|
import de.ellpeck.actuallyadditions.mod.util.ItemStackHandlerCustom;
|
||||||
import de.ellpeck.actuallyadditions.mod.util.*;
|
import de.ellpeck.actuallyadditions.mod.util.ModUtil;
|
||||||
|
import de.ellpeck.actuallyadditions.mod.util.StackUtil;
|
||||||
|
import de.ellpeck.actuallyadditions.mod.util.StringUtil;
|
||||||
import net.minecraft.client.util.ITooltipFlag;
|
import net.minecraft.client.util.ITooltipFlag;
|
||||||
import net.minecraft.entity.item.EntityItem;
|
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.EnumRarity;
|
import net.minecraft.item.EnumRarity;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
@ -29,10 +30,6 @@ import net.minecraft.util.EnumHand;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.text.TextFormatting;
|
import net.minecraft.util.text.TextFormatting;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraftforge.common.MinecraftForge;
|
|
||||||
import net.minecraftforge.event.entity.player.EntityItemPickupEvent;
|
|
||||||
import net.minecraftforge.fml.common.eventhandler.Event;
|
|
||||||
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
|
|
||||||
import net.minecraftforge.items.CapabilityItemHandler;
|
import net.minecraftforge.items.CapabilityItemHandler;
|
||||||
import net.minecraftforge.items.IItemHandler;
|
import net.minecraftforge.items.IItemHandler;
|
||||||
|
|
||||||
|
@ -41,16 +38,12 @@ import java.util.List;
|
||||||
|
|
||||||
public class ItemBag extends ItemBase{
|
public class ItemBag extends ItemBase{
|
||||||
|
|
||||||
private final boolean isVoid;
|
public final boolean isVoid;
|
||||||
|
|
||||||
public ItemBag(String name, boolean isVoid){
|
public ItemBag(String name, boolean isVoid){
|
||||||
super(name);
|
super(name);
|
||||||
this.isVoid = isVoid;
|
this.isVoid = isVoid;
|
||||||
this.setMaxStackSize(1);
|
this.setMaxStackSize(1);
|
||||||
|
|
||||||
if(!this.isVoid){ //So that the event stuff only runs once because this class is initialized twice
|
|
||||||
MinecraftForge.EVENT_BUS.register(this);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -69,82 +62,6 @@ public class ItemBag extends ItemBase{
|
||||||
tooltip.add(TextFormatting.ITALIC+String.format("%d/%d %s", slotsFilled, slotsTotal, StringUtil.localize("item."+ModUtil.MOD_ID+".item_bag.storage")));
|
tooltip.add(TextFormatting.ITALIC+String.format("%d/%d %s", slotsFilled, slotsTotal, StringUtil.localize("item."+ModUtil.MOD_ID+".item_bag.storage")));
|
||||||
}
|
}
|
||||||
|
|
||||||
@SubscribeEvent
|
|
||||||
public void onItemPickup(EntityItemPickupEvent event){
|
|
||||||
if(event.isCanceled() || event.getResult() == Event.Result.ALLOW){
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
EntityPlayer player = event.getEntityPlayer();
|
|
||||||
EntityItem item = event.getItem();
|
|
||||||
if(item != null && !item.isDead){
|
|
||||||
ItemStack stack = item.getEntityItem();
|
|
||||||
if(StackUtil.isValid(stack)){
|
|
||||||
for(int i = 0; i < player.inventory.getSizeInventory(); i++){
|
|
||||||
if(i != player.inventory.currentItem){
|
|
||||||
|
|
||||||
ItemStack invStack = player.inventory.getStackInSlot(i);
|
|
||||||
if(StackUtil.isValid(invStack) && invStack.getItem() instanceof ItemBag && invStack.hasTagCompound()){
|
|
||||||
if(invStack.getTagCompound().getBoolean("AutoInsert")){
|
|
||||||
boolean changed = false;
|
|
||||||
|
|
||||||
boolean isVoid = ((ItemBag)invStack.getItem()).isVoid;
|
|
||||||
ItemStackHandlerCustom inv = new ItemStackHandlerCustom(ContainerBag.getSlotAmount(isVoid));
|
|
||||||
ItemDrill.loadSlotsFromNBT(inv, invStack);
|
|
||||||
|
|
||||||
FilterSettings filter = new FilterSettings(4, false, false, false, false, 0, 0);
|
|
||||||
filter.readFromNBT(invStack.getTagCompound(), "Filter");
|
|
||||||
if(filter.check(stack)){
|
|
||||||
if(isVoid){
|
|
||||||
stack = StackUtil.setStackSize(stack, 0);
|
|
||||||
changed = true;
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
for(int j = 0; j < inv.getSlots(); j++){
|
|
||||||
ItemStack bagStack = inv.getStackInSlot(j);
|
|
||||||
if(StackUtil.isValid(bagStack)){
|
|
||||||
if(ItemUtil.canBeStacked(bagStack, stack)){
|
|
||||||
int maxTransfer = Math.min(StackUtil.getStackSize(stack), stack.getMaxStackSize()-StackUtil.getStackSize(bagStack));
|
|
||||||
if(maxTransfer > 0){
|
|
||||||
inv.setStackInSlot(j, StackUtil.addStackSize(bagStack, maxTransfer));
|
|
||||||
stack = StackUtil.addStackSize(stack, -maxTransfer);
|
|
||||||
changed = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
inv.setStackInSlot(j, stack.copy());
|
|
||||||
stack = StackUtil.setStackSize(stack, 0);
|
|
||||||
changed = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(!StackUtil.isValid(stack)){
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(changed){
|
|
||||||
if(!isVoid){
|
|
||||||
ItemDrill.writeSlotsToNBT(inv, invStack);
|
|
||||||
}
|
|
||||||
event.setResult(Event.Result.ALLOW);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(!StackUtil.isValid(stack)){
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
item.setEntityItemStack(stack);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EnumActionResult onItemUse(EntityPlayer playerIn, World worldIn, BlockPos pos, EnumHand hand, EnumFacing facing, float hitX, float hitY, float hitZ){
|
public EnumActionResult onItemUse(EntityPlayer playerIn, World worldIn, BlockPos pos, EnumHand hand, EnumFacing facing, float hitX, float hitY, float hitZ){
|
||||||
ItemStack stack = playerIn.getHeldItem(hand);
|
ItemStack stack = playerIn.getHeldItem(hand);
|
||||||
|
|
|
@ -12,7 +12,6 @@ package de.ellpeck.actuallyadditions.mod.items;
|
||||||
|
|
||||||
import de.ellpeck.actuallyadditions.mod.config.values.ConfigStringListValues;
|
import de.ellpeck.actuallyadditions.mod.config.values.ConfigStringListValues;
|
||||||
import de.ellpeck.actuallyadditions.mod.items.base.ItemBase;
|
import de.ellpeck.actuallyadditions.mod.items.base.ItemBase;
|
||||||
import de.ellpeck.actuallyadditions.mod.items.metalists.TheMiscItems;
|
|
||||||
import de.ellpeck.actuallyadditions.mod.util.ModUtil;
|
import de.ellpeck.actuallyadditions.mod.util.ModUtil;
|
||||||
import de.ellpeck.actuallyadditions.mod.util.StackUtil;
|
import de.ellpeck.actuallyadditions.mod.util.StackUtil;
|
||||||
import de.ellpeck.actuallyadditions.mod.util.StringUtil;
|
import de.ellpeck.actuallyadditions.mod.util.StringUtil;
|
||||||
|
@ -21,7 +20,6 @@ import net.minecraft.client.util.ITooltipFlag;
|
||||||
import net.minecraft.entity.EntityList;
|
import net.minecraft.entity.EntityList;
|
||||||
import net.minecraft.entity.EntityLivingBase;
|
import net.minecraft.entity.EntityLivingBase;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.init.Blocks;
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.tileentity.MobSpawnerBaseLogic;
|
import net.minecraft.tileentity.MobSpawnerBaseLogic;
|
||||||
|
@ -34,9 +32,6 @@ import net.minecraft.util.ResourceLocation;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.text.TextFormatting;
|
import net.minecraft.util.text.TextFormatting;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraftforge.common.MinecraftForge;
|
|
||||||
import net.minecraftforge.event.world.BlockEvent;
|
|
||||||
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
@ -45,16 +40,6 @@ public class ItemSpawnerChanger extends ItemBase{
|
||||||
public ItemSpawnerChanger(String name){
|
public ItemSpawnerChanger(String name){
|
||||||
super(name);
|
super(name);
|
||||||
this.setMaxStackSize(1);
|
this.setMaxStackSize(1);
|
||||||
|
|
||||||
MinecraftForge.EVENT_BUS.register(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
@SubscribeEvent
|
|
||||||
public void onBlockBreakEvent(BlockEvent.HarvestDropsEvent event){
|
|
||||||
IBlockState state = event.getState();
|
|
||||||
if(state != null && state.getBlock() == Blocks.MOB_SPAWNER){
|
|
||||||
event.getDrops().add(new ItemStack(InitItems.itemMisc, 1, TheMiscItems.SPAWNER_SHARD.ordinal()));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in a new issue