From 2a688e006c07c1240966c2829906a1752031153c Mon Sep 17 00:00:00 2001 From: draknyte1 Date: Thu, 2 Feb 2017 10:42:04 +1000 Subject: + Added a check for BuildCraft. % Changed handling of Wrench interfaces for the Workbench. - Removed classes I borrowed from MFR. (useless) - Removed Psychedelicraft support. (useless) --- .../xmod/forestry/trees/ForestryLeaf.java | 160 --------------------- .../xmod/forestry/trees/ForestrySapling.java | 55 ------- 2 files changed, 215 deletions(-) delete mode 100644 src/Java/gtPlusPlus/xmod/forestry/trees/ForestryLeaf.java delete mode 100644 src/Java/gtPlusPlus/xmod/forestry/trees/ForestrySapling.java (limited to 'src/Java/gtPlusPlus/xmod/forestry/trees') diff --git a/src/Java/gtPlusPlus/xmod/forestry/trees/ForestryLeaf.java b/src/Java/gtPlusPlus/xmod/forestry/trees/ForestryLeaf.java deleted file mode 100644 index e2550f4643..0000000000 --- a/src/Java/gtPlusPlus/xmod/forestry/trees/ForestryLeaf.java +++ /dev/null @@ -1,160 +0,0 @@ -package gtPlusPlus.xmod.forestry.trees; - -import java.util.*; - -import net.minecraft.block.Block; -import net.minecraft.item.Item; -import net.minecraft.item.ItemStack; -import net.minecraft.nbt.NBTTagCompound; -import net.minecraft.tileentity.TileEntity; -import net.minecraft.world.World; -import powercrystals.minefactoryreloaded.api.*; -import powercrystals.minefactoryreloaded.farmables.harvestables.HarvestableTreeLeaves; -import forestry.api.arboriculture.*; -import forestry.api.genetics.*; - - -public class ForestryLeaf extends HarvestableTreeLeaves implements IFactoryFruit -{ - private ITreeRoot root; - private ReplacementBlock repl; - protected Item _item; - - public ForestryLeaf(Block block) - { - super(block); - root = (ITreeRoot)AlleleManager.alleleRegistry.getSpeciesRoot("rootTrees"); - repl = EmptyReplacement.INSTANCE; - _item = Item.getItemFromBlock(block); - } - - @Override - public boolean canBePicked(World world, int x, int y, int z) - { - TileEntity te = world.getTileEntity(x, y, z); - if (te instanceof IFruitBearer) - { - IFruitBearer fruit = (IFruitBearer)te; - return fruit.getRipeness() >= 0.99f; - } - return false; - } - - public boolean canFertilize(World world, int x, int y, int z) - { - return !canBePicked(world, x, y, z); - } - - public boolean fertilize(World world, Random rand, int x, int y, int z) - { - TileEntity te = world.getTileEntity(x, y, z); - if (te instanceof IFruitBearer) - { - IFruitBearer fruit = (IFruitBearer)te; - fruit.addRipeness(1f); - return true; - } - return false; - } - - @Override - public ReplacementBlock getReplacementBlock(World world, int x, int y, int z) - { - return repl; - } - - @Override - public void prePick(World world, int x, int y, int z) - { - } - - @Override // HARVESTER - public List getDrops(World world, Random rand, Map settings, int x, int y, int z) - { - ITree tree = getTree(world, x, y, z); - if (tree == null) - return null; - - ArrayList prod = new ArrayList(); - - float modifier = 1f; - if (settings.get("silkTouch") == Boolean.TRUE) - { - ItemStack item = new ItemStack(_item); - NBTTagCompound tag = new NBTTagCompound(); - tree.writeToNBT(tag); - item.setTagCompound(tag); - prod.add(item); - } - else - { - boolean hasMate = tree.getMate() != null; - for (ITree s : getSaplings(tree, world, x, y, z, modifier)) - if (s != null) { - if ((hasMate && !s.isGeneticEqual(tree)) || rand.nextInt(32) == 0) - if (rand.nextBoolean()) - prod.add(root.getMemberStack(s, EnumGermlingType.POLLEN.ordinal())); - - prod.add(root.getMemberStack(s, EnumGermlingType.SAPLING.ordinal())); - } - - getFruits(world, x, y, z, tree, prod); - } - - return prod; - } - - - private static ITree[] getSaplings(ITree tree, World world, int x, int y, int z, float modifier) { - return tree.getSaplings(world, null, x, y, z, modifier); - } - - @Override // FRUIT PICKER - public List getDrops(World world, Random rand, int x, int y, int z) - { - ITree tree = getTree(world, x, y, z); - if (tree == null) - return null; - - ArrayList prod = new ArrayList(); - getFruits(world, x, y, z, tree, prod); - return prod; - } - - private ITree getTree(World world, int x, int y, int z) - { - TileEntity te = world.getTileEntity(x, y, z); - if (te instanceof IPollinatable) { - IIndividual t = ((IPollinatable)te).getPollen(); - if (t instanceof ITree) - return (ITree)t; - } - return null; - } - - private void getFruits(World world, int x, int y, int z, ITree tree, ArrayList prod) - { - TileEntity te = world.getTileEntity(x, y, z); - if (te instanceof IFruitBearer) - { - IFruitBearer fruit = (IFruitBearer)te; - if (fruit.hasFruit()) - { - //int period = tree.getGenome().getFruitProvider().getRipeningPeriod(); - //ItemStack[] o = tree.produceStacks(world, x, y, z, (int)(fruit.getRipeness() * period + 0.1f)); - prod.addAll(fruit.pickFruit(null)); - } - } - } - - @Override - public void postPick(World world, int x, int y, int z) - { - TileEntity te = world.getTileEntity(x, y, z); - if (te instanceof IFruitBearer) - { - IFruitBearer fruit = (IFruitBearer)te; - fruit.addRipeness(-fruit.getRipeness()); - } - } -} diff --git a/src/Java/gtPlusPlus/xmod/forestry/trees/ForestrySapling.java b/src/Java/gtPlusPlus/xmod/forestry/trees/ForestrySapling.java deleted file mode 100644 index 7c81ea0928..0000000000 --- a/src/Java/gtPlusPlus/xmod/forestry/trees/ForestrySapling.java +++ /dev/null @@ -1,55 +0,0 @@ -package gtPlusPlus.xmod.forestry.trees; - -import java.util.Random; - -import net.minecraft.block.Block; -import net.minecraft.item.Item; -import net.minecraft.item.ItemStack; -import net.minecraft.world.World; -import powercrystals.minefactoryreloaded.api.ReplacementBlock; -import powercrystals.minefactoryreloaded.farmables.plantables.PlantableStandard; -import forestry.api.arboriculture.ITreeRoot; -import forestry.api.genetics.AlleleManager; - -public class ForestrySapling extends PlantableStandard -{ - private ITreeRoot root; - - public ForestrySapling(Item item, Block block) - { - super(item, block, WILDCARD, null); - root = (ITreeRoot)AlleleManager.alleleRegistry.getSpeciesRoot("rootTrees"); - _plantedBlock = new ReplacementBlock((Block)null) { - @Override - public boolean replaceBlock(World world, int x, int y, int z, ItemStack stack) { - return root.plantSapling(world, root.getMember(stack), null, x, y, z); - } - }; - } - - public Block getPlant() - { - return _block; - } - - @Override - public boolean canBePlantedHere(World world, int x, int y, int z, ItemStack stack) - { - if (!world.isAirBlock(x, y, z)) - return false; - - return root.getMember(stack).canStay(world, x, y, z); - } - - public boolean canFertilize(World world, int x, int y, int z) - { - return true; - } - - public boolean fertilize(World world, Random rand, int x, int y, int z) - { - Block block = world.getBlock(x, y, z); - root.getTree(world, x, y, z).getTreeGenerator(world, x, y, z, true).generate(world, rand, x, y, z); - return world.getBlock(x, y, z) != block; - } -} -- cgit