package powercrystals.minefactoryreloaded.api; import net.minecraft.item.Item; import net.minecraft.item.ItemStack; import net.minecraft.world.World; /** * Defines a plantable object for use in the Planter. * * @author PowerCrystals */ public interface IFactoryPlantable { /** * @return The item this plantable is managing. */ public Item getSeed(); /** * @param stack * The stack being planted. * @param forFermenting * True if this stack will be converted to biofuel * * @return True if this plantable can be planted (useful for metadata * items). */ public boolean canBePlanted(ItemStack stack, boolean forFermenting); /** * @param world * The world instance this block or item will be placed into. * @param x * The destination X coordinate. * @param y * The destination Y coordinate. * @param z * The destination Z coordinate. * @param stack * The stack being planted. * * @return The block that will be placed into the world. */ public ReplacementBlock getPlantedBlock(World world, int x, int y, int z, ItemStack stack); /** * @param world * The world instance this block or item will be placed into. * @param x * The destination X coordinate. * @param y * The destination Y coordinate. * @param z * The destination Z coordinate. * @param stack * The stack being planted. * * @return True if this plantable can be placed at the provided coordinates. */ public boolean canBePlantedHere(World world, int x, int y, int z, ItemStack stack); /** * Called before planting is performed. Used to till soil, for example. * * @param world * The world instance this block or item will be placed into. * @param x * The destination X coordinate. * @param y * The destination Y coordinate. * @param z * The destination Z coordinate. * @param stack * The stack being planted. */ public void prePlant(World world, int x, int y, int z, ItemStack stack); /** * Called after planting is performed. Usually empty. * * @param world * The world instance this block or item will be placed into. * @param x * The destination X coordinate. * @param y * The destination Y coordinate. * @param z * The destination Z coordinate. * @param stack * The stack being planted. */ public void postPlant(World world, int x, int y, int z, ItemStack stack); }