Worked on processor and toyed with a few things
This commit is contained in:
parent
21af3b9d6d
commit
f5bc748171
10 changed files with 129 additions and 70 deletions
|
@ -2,22 +2,56 @@ package dark.api.energy;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import universalelectricity.core.vector.Vector3;
|
import universalelectricity.core.vector.Vector3;
|
||||||
|
|
||||||
import com.builtbroken.common.Pair;
|
import com.builtbroken.common.Pair;
|
||||||
|
import com.builtbroken.common.science.ChemElement;
|
||||||
|
|
||||||
/** Information about blocks not provided by minecraft such as density, mass, volume, heating values,
|
/** Information about blocks not provided by minecraft such as density, mass, volume, heating values,
|
||||||
* chemical properties, etc etc
|
* chemical properties, etc etc
|
||||||
*
|
*
|
||||||
* @author DarkGuardsman */
|
* @author DarkGuardsman */
|
||||||
public class ExtraBlockData
|
public class ExtraBlockData
|
||||||
{
|
{
|
||||||
HashMap<Pair<Integer, Integer>, HeatEnergyData> blockTempature = new HashMap();
|
private HashMap<Pair<Integer, Integer>, HeatEnergyData> blockTempature = new HashMap();
|
||||||
|
/** Map of blocks that can directly be linked to an element. This will be rare as most blocks are
|
||||||
|
* not one element type. */
|
||||||
|
private HashMap<Pair<Integer, Integer>, ChemElement> blockElement = new HashMap();
|
||||||
|
/** Very basic list of default temp of blocks */
|
||||||
|
private HashMap<Pair<Integer, Integer>, Integer> blockTempDefaults = new HashMap();
|
||||||
|
|
||||||
|
private static ExtraBlockData instance;
|
||||||
|
|
||||||
|
static
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ExtraBlockData instance()
|
||||||
|
{
|
||||||
|
if (instance == null)
|
||||||
|
{
|
||||||
|
instance = new ExtraBlockData();
|
||||||
|
}
|
||||||
|
return instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Returns a temp at the given location in kelvin
|
||||||
|
*
|
||||||
|
* @param world
|
||||||
|
* @param vec
|
||||||
|
* @return */
|
||||||
public static double getTempature(World world, Vector3 vec)
|
public static double getTempature(World world, Vector3 vec)
|
||||||
{
|
{
|
||||||
return 0;
|
if (world != null && vec != null)
|
||||||
|
{
|
||||||
|
int blockID = vec.getBlockID(world);
|
||||||
|
int meta = vec.getBlockMetadata(world);
|
||||||
|
TileEntity entity = vec.getTileEntity(world);
|
||||||
|
}
|
||||||
|
return 270;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class HeatEnergyData
|
public static class HeatEnergyData
|
||||||
|
@ -25,4 +59,23 @@ public class ExtraBlockData
|
||||||
public float maxTempature;
|
public float maxTempature;
|
||||||
public float defaultTempature;
|
public float defaultTempature;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void onWorldUpdate()
|
||||||
|
{
|
||||||
|
/*TODO tap into the world update to allow a slow recalculation of heat level per location.
|
||||||
|
* Remember to keep CPU time very low for this as it should be passive letting machines
|
||||||
|
* control the heat level rather than the world. Though a small amount of the machines heat
|
||||||
|
* output can be managed by this class
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
public void loadMap()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void saveMap()
|
||||||
|
{
|
||||||
|
//TODO tap into the chunk manager to save an extra layer of date for heat level for each block.
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,20 +4,20 @@ import net.minecraftforge.common.ForgeDirection;
|
||||||
import dark.api.parts.ITileConnector;
|
import dark.api.parts.ITileConnector;
|
||||||
|
|
||||||
/** Used by TileEntities or Entities to show heat stored and cooling rate of the object
|
/** Used by TileEntities or Entities to show heat stored and cooling rate of the object
|
||||||
*
|
*
|
||||||
* @author DarkGuardsman */
|
* @author DarkGuardsman */
|
||||||
public interface IHeatObject extends ITileConnector
|
public interface IHeatObject extends ITileConnector
|
||||||
{
|
{
|
||||||
|
|
||||||
/** Amount of heat stored in the body of the object. Think of it as a battery for heat but
|
/** Amount of heat stored in the body of the object. Think of it as a battery for heat but
|
||||||
* remember that heat is lost very fast
|
* remember that heat should be lost rather than keep over time.
|
||||||
*
|
*
|
||||||
* @return amount of heat in generic units */
|
* @return amount of heat in generic units */
|
||||||
public float getHeat(ForgeDirection side);
|
public float getHeat(ForgeDirection side);
|
||||||
|
|
||||||
/** Sets the heat level of the object or increase it
|
/** Sets the heat level of the object or increases it
|
||||||
*
|
*
|
||||||
* @param amount - amount to set or increase by
|
* @param amount - amount to set or increase by. Can be neg to indicate a lose of heat
|
||||||
* @param incrase - true if should increase the current heat level */
|
* @param incrase - true if should increase the current heat level */
|
||||||
public void setHeat(double amount, boolean incrase);
|
public void setHeat(double amount, boolean incrase);
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package dark.api;
|
package dark.api.reciepes;
|
||||||
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
/** Processor Recipe output Container. Input is controlled by the processor recipes class. */
|
/** Processor Recipe output Container. Input is controlled by the processor recipes class. */
|
|
@ -1,4 +1,4 @@
|
||||||
package dark.api;
|
package dark.api.reciepes;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
@ -15,6 +15,7 @@ import net.minecraftforge.oredict.OreDictionary;
|
||||||
import com.builtbroken.common.Pair;
|
import com.builtbroken.common.Pair;
|
||||||
|
|
||||||
import cpw.mods.fml.common.registry.GameRegistry;
|
import cpw.mods.fml.common.registry.GameRegistry;
|
||||||
|
import dark.api.ColorCode;
|
||||||
import dark.core.common.CoreRecipeLoader;
|
import dark.core.common.CoreRecipeLoader;
|
||||||
import dark.core.common.items.EnumMaterial;
|
import dark.core.common.items.EnumMaterial;
|
||||||
import dark.core.common.items.EnumOrePart;
|
import dark.core.common.items.EnumOrePart;
|
||||||
|
@ -157,15 +158,43 @@ public class ProcessorRecipes
|
||||||
* @return array of itemStacks */
|
* @return array of itemStacks */
|
||||||
public static ItemStack[] getOuput(ProcessorType type, ItemStack stack, boolean damageSalvage)
|
public static ItemStack[] getOuput(ProcessorType type, ItemStack stack, boolean damageSalvage)
|
||||||
{
|
{
|
||||||
if (stack == null || type == null || stack.getItem() == null)
|
if (stack != null && type != null)
|
||||||
{
|
{
|
||||||
return null;
|
ItemStack[] reList = getOuputNormal(type, stack);
|
||||||
|
if (reList == null)
|
||||||
|
{
|
||||||
|
reList = salvageItem(type, stack);
|
||||||
|
}
|
||||||
|
return reList;
|
||||||
}
|
}
|
||||||
Pair<Integer, Integer> blockSet = new Pair<Integer, Integer>(stack.itemID, stack.getItemDamage());
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
HashMap<Pair<Integer, Integer>, ItemStack> altSalvageMap = type.altOutput;
|
public static ItemStack[] salvageItem(ProcessorType type, ItemStack stack)
|
||||||
|
{
|
||||||
|
//TODO find a way around having to force single output size salvaging
|
||||||
|
ItemStack[] recipeList = AutoCraftingManager.getReverseRecipe(stack.copy(), 1);
|
||||||
|
ItemStack[] reList = new ItemStack[recipeList.length];
|
||||||
|
for (int i = 0; i < recipeList.length; i++)
|
||||||
|
{
|
||||||
|
if (recipeList[i] != null && random.nextFloat() >= .3f)
|
||||||
|
{
|
||||||
|
reList[i] = recipeList[i];
|
||||||
|
if (recipeList[i].itemID < Block.blocksList.length && Block.blocksList[recipeList[i].itemID] != null && recipeList[i].getItemDamage() > 16)
|
||||||
|
{
|
||||||
|
reList[i].setItemDamage(0);
|
||||||
|
}
|
||||||
|
if (type.altOutput != null && type.altOutput.containsKey(new Pair<Integer, Integer>(reList[i].itemID, reList[i].getItemDamage())))
|
||||||
|
{
|
||||||
|
reList[i] = convert(type.altOutput.get(new Pair<Integer, Integer>(reList[i].itemID, reList[i].getItemDamage())));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return reList;
|
||||||
|
}
|
||||||
|
|
||||||
//Read normal recipe map for outputs
|
public static ItemStack[] getOuputNormal(ProcessorType type, ItemStack stack)
|
||||||
|
{
|
||||||
if (type.itemRecipes != null)
|
if (type.itemRecipes != null)
|
||||||
{
|
{
|
||||||
ProcessorRecipe re = type.itemRecipes.get(new Pair<Integer, Integer>(stack.itemID, -1));
|
ProcessorRecipe re = type.itemRecipes.get(new Pair<Integer, Integer>(stack.itemID, -1));
|
||||||
|
@ -173,6 +202,10 @@ public class ProcessorRecipes
|
||||||
{
|
{
|
||||||
re = type.itemRecipes.get(new Pair<Integer, Integer>(stack.itemID, stack.getItemDamage()));
|
re = type.itemRecipes.get(new Pair<Integer, Integer>(stack.itemID, stack.getItemDamage()));
|
||||||
}
|
}
|
||||||
|
if (type.altOutput != null && (re == null || re.output == null))
|
||||||
|
{
|
||||||
|
return new ItemStack[] { type.altOutput.get(new Pair<Integer, Integer>(stack.itemID, stack.getItemDamage())) };
|
||||||
|
}
|
||||||
if (re != null && re.output != null)
|
if (re != null && re.output != null)
|
||||||
{
|
{
|
||||||
ItemStack output = re.output.copy();
|
ItemStack output = re.output.copy();
|
||||||
|
@ -185,48 +218,7 @@ public class ProcessorRecipes
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Read chance output map
|
return null;
|
||||||
Pair<ItemStack, Float> ree = mapChance.get(blockSet);
|
|
||||||
if (ree != null && random.nextFloat() >= ree.right())
|
|
||||||
{
|
|
||||||
return new ItemStack[] { convert(ree.left()) };
|
|
||||||
}
|
|
||||||
|
|
||||||
//Start salvaging items
|
|
||||||
ItemStack[] recipeList = AutoCraftingManager.getReverseRecipe(stack.copy());
|
|
||||||
ItemStack[] reList = null;
|
|
||||||
if (recipeList != null)
|
|
||||||
{
|
|
||||||
reList = new ItemStack[recipeList.length];
|
|
||||||
for (int i = 0; i < recipeList.length; i++)
|
|
||||||
{
|
|
||||||
if (recipeList[i] != null && random.nextFloat() >= .3f)
|
|
||||||
{
|
|
||||||
int meta = recipeList[i].getItemDamage();
|
|
||||||
reList[i] = recipeList[i];
|
|
||||||
if (recipeList[i].itemID < Block.blocksList.length && Block.blocksList[recipeList[i].itemID] != null && recipeList[i].getItemDamage() > 16)
|
|
||||||
{
|
|
||||||
reList[i].setItemDamage(0);
|
|
||||||
}
|
|
||||||
if (damageSalvage && altSalvageMap != null && altSalvageMap.containsKey(new Pair<Integer, Integer>(reList[i].itemID, reList[i].getItemDamage())))
|
|
||||||
{
|
|
||||||
reList[i] = convert(altSalvageMap.get(new Pair<Integer, Integer>(reList[i].itemID, reList[i].getItemDamage())));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return reList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static ItemStack[] getOuputNormal(ProcessorType type, ItemStack stack, boolean damageSalvage)
|
|
||||||
{
|
|
||||||
if (stack == null || type == null || stack.getItem() == null)
|
|
||||||
{
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
ItemStack[] reList = null;
|
|
||||||
|
|
||||||
return reList;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void parseOreNames(Configuration config)
|
public static void parseOreNames(Configuration config)
|
|
@ -8,8 +8,8 @@ import net.minecraft.item.crafting.FurnaceRecipes;
|
||||||
import net.minecraftforge.oredict.ShapedOreRecipe;
|
import net.minecraftforge.oredict.ShapedOreRecipe;
|
||||||
import cpw.mods.fml.common.registry.GameRegistry;
|
import cpw.mods.fml.common.registry.GameRegistry;
|
||||||
import dark.api.ColorCode;
|
import dark.api.ColorCode;
|
||||||
import dark.api.ProcessorRecipes;
|
import dark.api.reciepes.ProcessorRecipes;
|
||||||
import dark.api.ProcessorRecipes.ProcessorType;
|
import dark.api.reciepes.ProcessorRecipes.ProcessorType;
|
||||||
import dark.core.common.blocks.BlockBasalt;
|
import dark.core.common.blocks.BlockBasalt;
|
||||||
import dark.core.common.blocks.BlockOre;
|
import dark.core.common.blocks.BlockOre;
|
||||||
import dark.core.common.blocks.BlockOre.OreData;
|
import dark.core.common.blocks.BlockOre.OreData;
|
||||||
|
|
|
@ -33,8 +33,8 @@ import cpw.mods.fml.common.network.NetworkMod;
|
||||||
import cpw.mods.fml.common.network.NetworkRegistry;
|
import cpw.mods.fml.common.network.NetworkRegistry;
|
||||||
import cpw.mods.fml.common.registry.TickRegistry;
|
import cpw.mods.fml.common.registry.TickRegistry;
|
||||||
import cpw.mods.fml.relauncher.Side;
|
import cpw.mods.fml.relauncher.Side;
|
||||||
import dark.api.ProcessorRecipes;
|
import dark.api.reciepes.ProcessorRecipes;
|
||||||
import dark.api.ProcessorRecipes.ProcessorType;
|
import dark.api.reciepes.ProcessorRecipes.ProcessorType;
|
||||||
import dark.core.common.RecipeLoader.RecipeGrid;
|
import dark.core.common.RecipeLoader.RecipeGrid;
|
||||||
import dark.core.common.blocks.BlockBasalt;
|
import dark.core.common.blocks.BlockBasalt;
|
||||||
import dark.core.common.blocks.BlockColorGlass;
|
import dark.core.common.blocks.BlockColorGlass;
|
||||||
|
|
|
@ -9,7 +9,7 @@ import net.minecraft.nbt.NBTTagCompound;
|
||||||
* automation. As well this is not designed to replace the need for IInventory support of a tile but
|
* automation. As well this is not designed to replace the need for IInventory support of a tile but
|
||||||
* to make it easier to manage. Suggested use it to create a prefab manager for several tiles. Then
|
* to make it easier to manage. Suggested use it to create a prefab manager for several tiles. Then
|
||||||
* have those tiles use the prefab as an extermal inventory manager to reduce code size per class.
|
* have those tiles use the prefab as an extermal inventory manager to reduce code size per class.
|
||||||
*
|
*
|
||||||
* @author DarkGuardsman */
|
* @author DarkGuardsman */
|
||||||
public interface IInvBox extends ISidedInventory
|
public interface IInvBox extends ISidedInventory
|
||||||
{
|
{
|
||||||
|
@ -17,7 +17,7 @@ public interface IInvBox extends ISidedInventory
|
||||||
public ItemStack[] getContainedItems();
|
public ItemStack[] getContainedItems();
|
||||||
|
|
||||||
/** Called to save the inventory array */
|
/** Called to save the inventory array */
|
||||||
public void saveInv(NBTTagCompound tag);
|
public NBTTagCompound saveInv(NBTTagCompound tag);
|
||||||
|
|
||||||
/** Called to load the inventory array */
|
/** Called to load the inventory array */
|
||||||
public void loadInv(NBTTagCompound tag);
|
public void loadInv(NBTTagCompound tag);
|
||||||
|
|
|
@ -19,7 +19,7 @@ import cpw.mods.fml.common.event.FMLInitializationEvent;
|
||||||
import cpw.mods.fml.common.event.FMLPostInitializationEvent;
|
import cpw.mods.fml.common.event.FMLPostInitializationEvent;
|
||||||
import cpw.mods.fml.common.event.FMLPreInitializationEvent;
|
import cpw.mods.fml.common.event.FMLPreInitializationEvent;
|
||||||
import cpw.mods.fml.relauncher.Side;
|
import cpw.mods.fml.relauncher.Side;
|
||||||
import dark.api.ProcessorRecipes;
|
import dark.api.reciepes.ProcessorRecipes;
|
||||||
import dark.core.common.ExternalModHandler;
|
import dark.core.common.ExternalModHandler;
|
||||||
import dark.core.prefab.helpers.FluidHelper;
|
import dark.core.prefab.helpers.FluidHelper;
|
||||||
import dark.core.registration.ModObjectRegistry;
|
import dark.core.registration.ModObjectRegistry;
|
||||||
|
|
|
@ -96,7 +96,7 @@ public class AutoCraftingManager
|
||||||
{
|
{
|
||||||
ShapelessOreRecipe oreRecipe = (ShapelessOreRecipe) recipe;
|
ShapelessOreRecipe oreRecipe = (ShapelessOreRecipe) recipe;
|
||||||
ArrayList oreRecipeInput = (ArrayList) ReflectionHelper.getPrivateValue(ShapelessOreRecipe.class, oreRecipe, "input");
|
ArrayList oreRecipeInput = (ArrayList) ReflectionHelper.getPrivateValue(ShapelessOreRecipe.class, oreRecipe, "input");
|
||||||
for(Object obj : oreRecipeInput)
|
for (Object obj : oreRecipeInput)
|
||||||
{
|
{
|
||||||
System.out.println(obj);
|
System.out.println(obj);
|
||||||
}
|
}
|
||||||
|
@ -194,7 +194,7 @@ public class AutoCraftingManager
|
||||||
|
|
||||||
/** Gets a basic array containing all items that were used to craft the given item. Doesn't sort
|
/** Gets a basic array containing all items that were used to craft the given item. Doesn't sort
|
||||||
* threw the recipes and will return the first possible recipe */
|
* threw the recipes and will return the first possible recipe */
|
||||||
public static ItemStack[] getReverseRecipe(ItemStack outputItem)
|
public static ItemStack[] getReverseRecipe(ItemStack outputItem, int outputSize)
|
||||||
{
|
{
|
||||||
|
|
||||||
for (Object object : CraftingManager.getInstance().getRecipeList())
|
for (Object object : CraftingManager.getInstance().getRecipeList())
|
||||||
|
@ -203,7 +203,7 @@ public class AutoCraftingManager
|
||||||
{
|
{
|
||||||
if (((IRecipe) object).getRecipeOutput() != null)
|
if (((IRecipe) object).getRecipeOutput() != null)
|
||||||
{
|
{
|
||||||
if (((IRecipe) object).getRecipeOutput().isItemEqual(outputItem))
|
if (((IRecipe) object).getRecipeOutput().isItemEqual(outputItem) && (outputSize == -1 || ((IRecipe) object).getRecipeOutput().stackSize == outputItem.stackSize))
|
||||||
{
|
{
|
||||||
if (object instanceof ShapedRecipes)
|
if (object instanceof ShapedRecipes)
|
||||||
{
|
{
|
||||||
|
@ -239,7 +239,7 @@ public class AutoCraftingManager
|
||||||
{
|
{
|
||||||
ItemStack recipeItem = (ItemStack) ingredientsArray[x];
|
ItemStack recipeItem = (ItemStack) ingredientsArray[x];
|
||||||
actualResources.add(recipeItem.copy());
|
actualResources.add(recipeItem.copy());
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
package dark.core.prefab.invgui;
|
package dark.core.prefab.invgui;
|
||||||
|
|
||||||
|
import net.minecraft.entity.Entity;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
|
@ -34,6 +35,12 @@ public class InvChest implements IInvBox
|
||||||
this(chest, ((IExternalInv) chest), slots);
|
this(chest, ((IExternalInv) chest), slots);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public InvChest(Entity entity, int i)
|
||||||
|
{
|
||||||
|
this.slots = i;
|
||||||
|
this.inv = (IExternalInv) entity;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getSizeInventory()
|
public int getSizeInventory()
|
||||||
{
|
{
|
||||||
|
@ -176,14 +183,20 @@ public class InvChest implements IInvBox
|
||||||
@Override
|
@Override
|
||||||
public void onInventoryChanged()
|
public void onInventoryChanged()
|
||||||
{
|
{
|
||||||
|
if(this.hostTile != null){
|
||||||
this.hostTile.onInventoryChanged();
|
this.hostTile.onInventoryChanged();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isUseableByPlayer(EntityPlayer par1EntityPlayer)
|
public boolean isUseableByPlayer(EntityPlayer par1EntityPlayer)
|
||||||
{
|
{
|
||||||
|
if(this.hostTile != null)
|
||||||
|
{
|
||||||
return this.hostTile.worldObj.getBlockTileEntity(this.hostTile.xCoord, this.hostTile.yCoord, this.hostTile.zCoord) != this.hostTile ? false : par1EntityPlayer.getDistanceSq(this.hostTile.xCoord + 0.5D, this.hostTile.yCoord + 0.5D, this.hostTile.zCoord + 0.5D) <= 64.0D;
|
return this.hostTile.worldObj.getBlockTileEntity(this.hostTile.xCoord, this.hostTile.yCoord, this.hostTile.zCoord) != this.hostTile ? false : par1EntityPlayer.getDistanceSq(this.hostTile.xCoord + 0.5D, this.hostTile.yCoord + 0.5D, this.hostTile.zCoord + 0.5D) <= 64.0D;
|
||||||
}
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ItemStack[] getContainedItems()
|
public ItemStack[] getContainedItems()
|
||||||
|
@ -196,7 +209,7 @@ public class InvChest implements IInvBox
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void saveInv(NBTTagCompound nbt)
|
public NBTTagCompound saveInv(NBTTagCompound nbt)
|
||||||
{
|
{
|
||||||
NBTTagList itemList = new NBTTagList();
|
NBTTagList itemList = new NBTTagList();
|
||||||
for (int s = 0; s < this.getContainedItems().length; ++s)
|
for (int s = 0; s < this.getContainedItems().length; ++s)
|
||||||
|
@ -210,6 +223,7 @@ public class InvChest implements IInvBox
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
nbt.setTag("Items", itemList);
|
nbt.setTag("Items", itemList);
|
||||||
|
return nbt;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in a new issue