From 07eb79cdd0906c528017b53214f679a8d09915b6 Mon Sep 17 00:00:00 2001 From: DarkGuardsman Date: Fri, 20 Sep 2013 12:01:52 -0400 Subject: [PATCH] FixedIssuesWithRegistry --- src/dark/core/common/DarkMain.java | 58 +++++-------------- src/dark/core/common/blocks/BlockOre.java | 2 +- src/dark/core/common/debug/BlockDebug.java | 5 +- .../common/machines/BlockBasicMachine.java | 3 +- src/dark/core/common/transmit/BlockWire.java | 3 +- src/dark/core/registration/BlockFluid.java | 2 +- .../core/registration/ModObjectRegistry.java | 43 ++++++++------ 7 files changed, 48 insertions(+), 68 deletions(-) diff --git a/src/dark/core/common/DarkMain.java b/src/dark/core/common/DarkMain.java index 51914e5ff..407c86546 100644 --- a/src/dark/core/common/DarkMain.java +++ b/src/dark/core/common/DarkMain.java @@ -33,6 +33,7 @@ import cpw.mods.fml.common.event.FMLServerStoppingEvent; import cpw.mods.fml.common.network.NetworkMod; import cpw.mods.fml.common.network.NetworkRegistry; import dark.api.ProcessorRecipes; +import dark.core.common.blocks.BlockBasalt; import dark.core.common.blocks.BlockColorGlass; import dark.core.common.blocks.BlockColorGlowGlass; import dark.core.common.blocks.BlockColorSand; @@ -184,15 +185,19 @@ public class DarkMain extends ModPrefab /* CONFIGS */ CONFIGURATION.load(); /* BLOCKS */ - blockMulti = (BlockMulti) ModObjectRegistry.createNewBlock(DarkMain.MOD_ID, BlockMulti.class, false); - basicMachine = ModObjectRegistry.createNewBlock(DarkMain.MOD_ID, BlockBasicMachine.class, ItemBlockHolder.class); - CoreRecipeLoader.blockOre = ModObjectRegistry.createNewBlock(DarkMain.MOD_ID, BlockOre.class, ItemBlockOre.class); - CoreRecipeLoader.blockWire = ModObjectRegistry.createNewBlock(DarkMain.MOD_ID, BlockWire.class, ItemBlockHolder.class); - CoreRecipeLoader.blockDebug = ModObjectRegistry.createNewBlock(DarkMain.MOD_ID, BlockDebug.class, ItemBlockHolder.class); - CoreRecipeLoader.blockStainGlass = ModObjectRegistry.createNewBlock(DarkMain.MOD_ID, BlockColorGlass.class, ItemBlockColored.class); - CoreRecipeLoader.blockColorSand = ModObjectRegistry.createNewBlock(DarkMain.MOD_ID, BlockColorSand.class, ItemBlockColored.class); - CoreRecipeLoader.blockBasalt = ModObjectRegistry.createNewBlock(DarkMain.MOD_ID, BlockColorSand.class, ItemBlockColored.class); - CoreRecipeLoader.blockGlowGlass = ModObjectRegistry.createNewBlock(DarkMain.MOD_ID, BlockColorGlowGlass.class, ItemBlockColored.class); + Block m = ModObjectRegistry.createNewBlock("DMBlockMulti", DarkMain.MOD_ID, BlockMulti.class, false); + if (m instanceof BlockMulti) + { + blockMulti = (BlockMulti) m; + } + basicMachine = ModObjectRegistry.createNewBlock("DMBlockBasicMachine", DarkMain.MOD_ID, BlockBasicMachine.class, ItemBlockHolder.class); + CoreRecipeLoader.blockOre = ModObjectRegistry.createNewBlock("DMBlockOre", DarkMain.MOD_ID, BlockOre.class, ItemBlockOre.class); + CoreRecipeLoader.blockWire = ModObjectRegistry.createNewBlock("DMBlockWire", DarkMain.MOD_ID, BlockWire.class, ItemBlockHolder.class); + CoreRecipeLoader.blockDebug = ModObjectRegistry.createNewBlock("DMBlockDebug", DarkMain.MOD_ID, BlockDebug.class, ItemBlockHolder.class); + CoreRecipeLoader.blockStainGlass = ModObjectRegistry.createNewBlock("DMBlockStainedGlass", DarkMain.MOD_ID, BlockColorGlass.class, ItemBlockColored.class); + CoreRecipeLoader.blockColorSand = ModObjectRegistry.createNewBlock("DMBlockColorSand", DarkMain.MOD_ID, BlockColorSand.class, ItemBlockColored.class); + CoreRecipeLoader.blockBasalt = ModObjectRegistry.createNewBlock("DMBlockBasalt", DarkMain.MOD_ID, BlockBasalt.class, ItemBlockColored.class); + CoreRecipeLoader.blockGlowGlass = ModObjectRegistry.createNewBlock("DMBlockGlowGlass", DarkMain.MOD_ID, BlockColorGlowGlass.class, ItemBlockColored.class); /* ITEMS */ CoreRecipeLoader.itemTool = new ItemTools(ITEM_ID_PREFIX++, DarkMain.CONFIGURATION); @@ -253,41 +258,6 @@ public class DarkMain extends ModPrefab return "dark"; } - /** Creative tab for generic items and block that don't belong in any other tab */ - public static CreativeTabs tabGSMGeneral = new CreativeTabs("AutomationMachines") - { - @Override - public ItemStack getIconItemStack() - { - return new ItemStack(Item.ingotIron, 1, 0); - } - }; - /** Creative tab for High tech and industrial based items and blocks that don't belong in any - * other tab */ - public static CreativeTabs tabIndustrial = new CreativeTabs("IndustrialMachines") - { - ItemStack tabItemStack = new ItemStack(Item.ingotIron, 1, 0); - @Override - public ItemStack getIconItemStack() - { - if (DarkMain.basicMachine != null) - { - new ItemStack(DarkMain.basicMachine.blockID, 1, 0); - } - return tabItemStack; - } - }; - /** Creative tab for general castle and fortress related items and blocks that don't belong in - * any other tab */ - public static CreativeTabs tabHydrualic = new CreativeTabs("HydraulicMachines") - { - - @Override - public ItemStack getIconItemStack() - { - return new ItemStack(Item.ingotIron, 1, 0); - } - }; } diff --git a/src/dark/core/common/blocks/BlockOre.java b/src/dark/core/common/blocks/BlockOre.java index c3438a197..b044d894c 100644 --- a/src/dark/core/common/blocks/BlockOre.java +++ b/src/dark/core/common/blocks/BlockOre.java @@ -97,7 +97,7 @@ public class BlockOre extends Block implements IExtraObjectInfo { if (EnumMeterials.values()[i].doWorldGen) { - OreDictionary.registerOre(EnumMeterials.values()[i].name + "Ore", new ItemStack(CoreRecipeLoader.blockOre.blockID, 1, i)); + OreDictionary.registerOre(EnumMeterials.values()[i].name + "Ore", new ItemStack(this.blockID, 1, i)); } } diff --git a/src/dark/core/common/debug/BlockDebug.java b/src/dark/core/common/debug/BlockDebug.java index bc886f54c..e60926ef1 100644 --- a/src/dark/core/common/debug/BlockDebug.java +++ b/src/dark/core/common/debug/BlockDebug.java @@ -13,6 +13,7 @@ import net.minecraft.world.World; import net.minecraftforge.common.Configuration; import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.SideOnly; +import dark.core.common.DMCreativeTab; import dark.core.common.DarkMain; import dark.core.prefab.IExtraObjectInfo; import dark.core.prefab.helpers.Pair; @@ -23,9 +24,9 @@ public class BlockDebug extends BlockMachine implements IExtraObjectInfo { public static float DebugWattOut, DebugWattDemand; - public BlockDebug(int blockID) + public BlockDebug() { - super(new BlockBuildData(BlockDebug.class, "DebugBlock", Material.clay).setCreativeTab(DarkMain.tabIndustrial)); + super(new BlockBuildData(BlockDebug.class, "DebugBlock", Material.clay).setCreativeTab(DMCreativeTab.tabIndustrial)); } @Override diff --git a/src/dark/core/common/machines/BlockBasicMachine.java b/src/dark/core/common/machines/BlockBasicMachine.java index e5915c024..d027ed1f1 100644 --- a/src/dark/core/common/machines/BlockBasicMachine.java +++ b/src/dark/core/common/machines/BlockBasicMachine.java @@ -14,6 +14,7 @@ import net.minecraft.world.World; import net.minecraftforge.common.Configuration; import universalelectricity.core.UniversalElectricity; import dark.core.common.CommonProxy; +import dark.core.common.DMCreativeTab; import dark.core.common.DarkMain; import dark.core.prefab.IExtraObjectInfo; import dark.core.prefab.helpers.Pair; @@ -25,7 +26,7 @@ public class BlockBasicMachine extends BlockMachine implements IExtraObjectInfo public BlockBasicMachine() { - super(new BlockBuildData(BlockBasicMachine.class, "BasicMachine", UniversalElectricity.machine).setCreativeTab(DarkMain.tabIndustrial)); + super(new BlockBuildData(BlockBasicMachine.class, "BasicMachine", UniversalElectricity.machine).setCreativeTab(DMCreativeTab.tabIndustrial)); this.setStepSound(soundMetalFootstep); } diff --git a/src/dark/core/common/transmit/BlockWire.java b/src/dark/core/common/transmit/BlockWire.java index 650326d27..e2cfdd6cf 100644 --- a/src/dark/core/common/transmit/BlockWire.java +++ b/src/dark/core/common/transmit/BlockWire.java @@ -16,6 +16,7 @@ import net.minecraftforge.common.Configuration; import universalelectricity.core.block.IConductor; import universalelectricity.core.vector.Vector3; import universalelectricity.prefab.tile.TileEntityConductor; +import dark.core.common.DMCreativeTab; import dark.core.common.DarkMain; import dark.core.prefab.IExtraObjectInfo; import dark.core.prefab.helpers.Pair; @@ -32,7 +33,7 @@ public class BlockWire extends BlockMachine implements IExtraObjectInfo public BlockWire() { - super(new BlockBuildData(BlockWire.class, "DMWire", Material.cloth).setCreativeTab(DarkMain.tabIndustrial)); + super(new BlockBuildData(BlockWire.class, "DMWire", Material.cloth).setCreativeTab(DMCreativeTab.tabIndustrial)); this.setStepSound(soundClothFootstep); this.setResistance(0.2F); this.setHardness(0.1f); diff --git a/src/dark/core/registration/BlockFluid.java b/src/dark/core/registration/BlockFluid.java index 47f71f9b8..d9b589095 100644 --- a/src/dark/core/registration/BlockFluid.java +++ b/src/dark/core/registration/BlockFluid.java @@ -19,7 +19,7 @@ public class BlockFluid extends BlockFluidFinite public BlockFluid(String prefix, Fluid fluid, Configuration config) { - super(config.getBlock(fluid.getName(), DarkMain.getNextID()).getInt(), fluid, Material.water); + super(config.getBlock("BlockFluid" + fluid.getName(), DarkMain.getNextID()).getInt(), fluid, Material.water); this.fluid = fluid; if (prefix != null && prefix.contains(":")) { diff --git a/src/dark/core/registration/ModObjectRegistry.java b/src/dark/core/registration/ModObjectRegistry.java index ff13b8e77..6bab42616 100644 --- a/src/dark/core/registration/ModObjectRegistry.java +++ b/src/dark/core/registration/ModObjectRegistry.java @@ -31,25 +31,25 @@ public class ModObjectRegistry { public static Configuration masterBlockConfig = new Configuration(new File(Loader.instance().getConfigDir(), "Dark/EnabledBlocks.cfg")); - public static Block createNewBlock(String modID, Class blockClass) + public static Block createNewBlock(String name, String modID, Class blockClass) { - return ModObjectRegistry.createNewBlock(modID, blockClass, true); + return ModObjectRegistry.createNewBlock(name, modID, blockClass, true); } - public static Block createNewBlock(String modID, Class blockClass, boolean canDisable) + public static Block createNewBlock(String name, String modID, Class blockClass, boolean canDisable) { - return ModObjectRegistry.createNewBlock(modID, blockClass, null, canDisable); + return ModObjectRegistry.createNewBlock(name, modID, blockClass, null, canDisable); } - public static Block createNewBlock(String modID, Class blockClass, Class itemClass) + public static Block createNewBlock(String name, String modID, Class blockClass, Class itemClass) { - return createNewBlock(modID, blockClass, itemClass, true); + return createNewBlock(name, modID, blockClass, itemClass, true); } - public static Block createNewBlock(String modID, Class blockClass, Class itemClass, boolean canDisable) + public static Block createNewBlock(String name, String modID, Class blockClass, Class itemClass, boolean canDisable) { Block block = null; - if (blockClass != null && (!canDisable || canDisable && masterBlockConfig.get("Enabled_List", "Enabled_" + block.getUnlocalizedName().replace("tile.", ""), true).getBoolean(true))) + if (blockClass != null && (!canDisable || canDisable && masterBlockConfig.get("Enabled_List", "Enabled_" + name, true).getBoolean(true))) { try { @@ -62,7 +62,7 @@ public class ModObjectRegistry if (block != null) { ModObjectRegistry.finishCreation(block, null); - ModObjectRegistry.registerBlock(block, itemClass, block.getUnlocalizedName().replace("tile.", ""), modID); + ModObjectRegistry.registerBlock(block, itemClass, name, modID); } } return block; @@ -91,14 +91,21 @@ public class ModObjectRegistry { constructor.setAccessible(true); - block = (Block) constructor.newInstance(buildData.config.getBlock(buildData.blockName, DarkMain.getNextID()), buildData.blockMaterial); - + Object obj = (Block) constructor.newInstance(buildData.config.getBlock(buildData.blockName, DarkMain.getNextID()), buildData.blockMaterial); + if (obj instanceof Block) + { + block = (Block) obj; + } } } else { constructor.setAccessible(true); - block = (Block) constructor.newInstance(buildData); + Object obj = constructor.newInstance(buildData); + if (obj instanceof Block) + { + block = (Block) obj; + } } ModObjectRegistry.finishCreation(block, buildData); @@ -235,13 +242,13 @@ public class ModObjectRegistry public static void registerBlock(Block block, Class itemClass, String name, String modID) { - if (block != null && name != null && !name.isEmpty()) + if (block != null && name != null) { - if (itemClass == null) - { - itemClass = ItemBlock.class; - } - GameRegistry.registerBlock(block, itemClass, name, modID); + + System.out.println("Block: " + (block == null ? "null" : block.toString())); + System.out.println("Item: " + (itemClass == null ? "null" : itemClass.toString())); + System.out.println("name: " + name.toString()); + GameRegistry.registerBlock(block, itemClass == null ? ItemBlock.class : itemClass, name, modID); } }