From 70c1354a4a96698758a88c032866288f79de6f5a Mon Sep 17 00:00:00 2001 From: Benjamin Culkin Date: Sat, 24 Aug 2024 08:16:37 -0400 Subject: Initial commit --- .../fbs/storage/TileEntityMealOutletSingle.java | 124 +++++++++++++++++++++ 1 file changed, 124 insertions(+) create mode 100644 src/main/java/jp/plusplus/fbs/storage/TileEntityMealOutletSingle.java (limited to 'src/main/java/jp/plusplus/fbs/storage/TileEntityMealOutletSingle.java') diff --git a/src/main/java/jp/plusplus/fbs/storage/TileEntityMealOutletSingle.java b/src/main/java/jp/plusplus/fbs/storage/TileEntityMealOutletSingle.java new file mode 100644 index 0000000..e79ca17 --- /dev/null +++ b/src/main/java/jp/plusplus/fbs/storage/TileEntityMealOutletSingle.java @@ -0,0 +1,124 @@ +package jp.plusplus.fbs.storage; + +import net.minecraft.inventory.IInventory; +import net.minecraft.inventory.ISidedInventory; +import net.minecraft.item.ItemStack; +import net.minecraft.nbt.NBTTagCompound; +import net.minecraft.tileentity.TileEntity; +import net.minecraft.tileentity.TileEntityChest; +import net.minecraft.tileentity.TileEntityFurnace; +import net.minecraftforge.common.util.ForgeDirection; + +/** + * Created by plusplus_F on 2016/03/07. + */ +public class TileEntityMealOutletSingle extends TileEntityMealInlet { + public ItemStack requirement; + + @Override + public void readFromNBT(NBTTagCompound par1NBTTagCompound){ + super.readFromNBT(par1NBTTagCompound); + if(par1NBTTagCompound.hasKey("Requirement")) requirement=ItemStack.loadItemStackFromNBT(par1NBTTagCompound.getCompoundTag("Requirement")); + else requirement=null; + } + @Override + public void writeToNBT(NBTTagCompound par1NBTTagCompound){ + super.writeToNBT(par1NBTTagCompound); + if(requirement!=null) par1NBTTagCompound.setTag("Requirement", requirement.writeToNBT(new NBTTagCompound())); + } + + public boolean hasRequirement(){ + return requirement!=null; + } + public ItemStack getRequirement(){ + return requirement; + } + public void setRequirement(ItemStack req){ + requirement=req; + } + + protected ItemStack getItemStack(){ + if(!hasRequirement() && !hasFragment()) return null; + + TileEntityMeal tem=ItemMealFragment.getTileEntity(getFragment()); + return tem.exportItemStack(requirement, requirement.stackSize); + } + + @Override + public void updateEntity(){ + if(!worldObj.isRemote && requirement!=null && worldObj.getWorldTime()%10==0){ + TileEntityMeal tem=ItemMealFragment.getTileEntity(fragment); + if(tem==null) return; + + ForgeDirection dir=ForgeDirection.getOrientation(worldObj.getBlockMetadata(xCoord, yCoord, zCoord)&7); + TileEntity te=worldObj.getTileEntity(xCoord+dir.offsetX, yCoord+dir.offsetY, zCoord+dir.offsetZ); + + if(te instanceof ISidedInventory){ + ISidedInventory inv=(ISidedInventory)te; + int side=dir.ordinal()^1; + int[] index=inv.getAccessibleSlotsFromSide(side); + + for(int i=0;i