diff options
author | Antifluxfield <lyj_299792458@163.com> | 2017-06-30 03:52:51 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-06-30 03:52:51 +0800 |
commit | 5995a20bb64f64fad80aae18a35dff2420ea3c7d (patch) | |
tree | 48cbf8b22e51771ab688c81aff74a33b0e141d30 /src | |
parent | 53ca200a2ee7ca7024858664fd1404ad1a9779a7 (diff) | |
download | GT5-Unofficial-5995a20bb64f64fad80aae18a35dff2420ea3c7d.tar.gz GT5-Unofficial-5995a20bb64f64fad80aae18a35dff2420ea3c7d.tar.bz2 GT5-Unofficial-5995a20bb64f64fad80aae18a35dff2420ea3c7d.zip |
Check for DataItems
Diffstat (limited to 'src')
-rw-r--r-- | src/main/java/gregtech/api/metatileentity/implementations/GT_MetaTileEntity_MultiBlockBase.java | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/src/main/java/gregtech/api/metatileentity/implementations/GT_MetaTileEntity_MultiBlockBase.java b/src/main/java/gregtech/api/metatileentity/implementations/GT_MetaTileEntity_MultiBlockBase.java index 6e163ebbba..b0bbb04fe8 100644 --- a/src/main/java/gregtech/api/metatileentity/implementations/GT_MetaTileEntity_MultiBlockBase.java +++ b/src/main/java/gregtech/api/metatileentity/implementations/GT_MetaTileEntity_MultiBlockBase.java @@ -695,6 +695,35 @@ public abstract class GT_MetaTileEntity_MultiBlockBase extends MetaTileEntity { return rList; } + /** + * @param state 0 for both, 1 for DataStick, 2 for DataOrb + */ + private boolean isCorrectDataItem(ItemStack aStack, byte state){ + if (ItemList.Tool_DataStick.isStackEqual(aStack, false, true) && (state == 0 || state == 1)) return true; + if (ItemList.Tool_DataOrb.isStackEqual(aStack, false, true) && (state == 0 || state == 2)) return true; + return false; + } + + /** + * @param state 0 for both, 1 for DataStick, 2 for DataOrb + */ + public ArrayList<ItemStack> getDataItems(byte state) { + ArrayList<ItemStack> rList = new ArrayList<ItemStack>(); + if (GT_Utility.isStackValid(mInventory[1]) && isCorrectDataItem(mInventory[1], state)) { + rList.add(mInventory[1]); + } + for (GT_MetaTileEntity_Hatch_DataAccess tHatch : mDataAccessHatches) { + if (isValidMetaTileEntity(tHatch)) { + for (int i = 0; i < tHatch.getBaseMetaTileEntity().getSizeInventory(); i++) { + if (tHatch.getBaseMetaTileEntity().getStackInSlot(i) != null + && isCorrectDataItem(tHatch.getBaseMetaTileEntity().getStackInSlot(i), state)) + rList.add(tHatch.getBaseMetaTileEntity().getStackInSlot(i)); + } + } + } + return rList; + } + public GT_Recipe_Map getRecipeMap() { return null; } |