From b3cbd7a54506c91ba20449e536642ec2c8344e99 Mon Sep 17 00:00:00 2001 From: David Vierra Date: Thu, 9 Jan 2020 19:58:57 -1000 Subject: [PATCH] Small Orchids properly decay after being replanted --- .../botania/SubTileSmallOrechid.java | 34 +++++++++++++++++++ 1 file changed, 34 insertions(+) diff --git a/src/main/java/com/gmail/pharaun/gregtania/botania/SubTileSmallOrechid.java b/src/main/java/com/gmail/pharaun/gregtania/botania/SubTileSmallOrechid.java index 0579af8..57ae716 100644 --- a/src/main/java/com/gmail/pharaun/gregtania/botania/SubTileSmallOrechid.java +++ b/src/main/java/com/gmail/pharaun/gregtania/botania/SubTileSmallOrechid.java @@ -7,10 +7,15 @@ import gregapi.data.CS; import gregapi.oredict.OreDictMaterial; import net.minecraft.block.Block; +import net.minecraft.entity.EntityLivingBase; import net.minecraft.init.Blocks; +import net.minecraft.item.ItemStack; +import net.minecraft.nbt.NBTTagCompound; import net.minecraft.util.ChunkCoordinates; import net.minecraft.util.WeightedRandom; +import net.minecraft.world.World; import net.minecraftforge.common.util.ForgeDirection; +import vazkii.botania.api.BotaniaAPI; import vazkii.botania.api.lexicon.LexiconEntry; import vazkii.botania.api.subtile.RadiusDescriptor; import vazkii.botania.api.subtile.SubTileFunctional; @@ -142,4 +147,33 @@ public RadiusDescriptor getRadius() { public int getMaxMana() { return getCost(); } + + public ArrayList getDrops(ArrayList list) { + ArrayList drops = super.getDrops(list); + this.populateDropStackNBTs(drops); + return drops; + } + + public void populateDropStackNBTs(List drops) { + if (this.ticksExisted > 0) { + ItemStack drop = drops.get(0); + if (drop != null) { + if (!drop.hasTagCompound()) { + drop.setTagCompound(new NBTTagCompound()); + } + + NBTTagCompound cmp = drop.getTagCompound(); + cmp.setInteger("ticksExisted", this.ticksExisted); + } + } + + } + + public void onBlockPlacedBy(World world, int x, int y, int z, EntityLivingBase entity, ItemStack stack) { + super.onBlockPlacedBy(world, x, y, z, entity, stack); + NBTTagCompound cmp = stack.getTagCompound(); + this.ticksExisted = cmp.getInteger("ticksExisted"); + + } + }