diff --git a/gradle.properties b/gradle.properties index 329bfbd6e..1e54dc1c8 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,5 +1,5 @@ minecraft_version=1.8 -forge_version=1.8-11.14.3.1449 -mod_version=2.1.6 +forge_version=1.8-11.14.3.1450 +mod_version=2.1.7 chameleon_version=0.1.0 chameleon_max_version=1.0.0 \ No newline at end of file diff --git a/src/com/jaquadro/minecraft/storagedrawers/block/tile/TileEntityDrawersComp.java b/src/com/jaquadro/minecraft/storagedrawers/block/tile/TileEntityDrawersComp.java index 0479cafb4..adf7d0fae 100644 --- a/src/com/jaquadro/minecraft/storagedrawers/block/tile/TileEntityDrawersComp.java +++ b/src/com/jaquadro/minecraft/storagedrawers/block/tile/TileEntityDrawersComp.java @@ -16,13 +16,17 @@ import net.minecraft.item.crafting.IRecipe; import net.minecraft.nbt.NBTTagCompound; import net.minecraft.util.ResourceLocation; +import net.minecraftforge.fml.common.FMLLog; import net.minecraftforge.fml.common.network.NetworkRegistry; import net.minecraftforge.fml.common.network.simpleimpl.IMessage; import net.minecraftforge.fml.common.registry.GameData; import net.minecraftforge.fml.common.registry.GameRegistry; +import org.apache.logging.log4j.Level; import java.util.ArrayList; +import java.util.HashMap; import java.util.List; +import java.util.Map; public class TileEntityDrawersComp extends TileEntityDrawers { @@ -181,6 +185,9 @@ private void populateSlots (ItemStack stack) { ItemStack lTier1 = findLowerTier(stack); if (lTier1 != null) { + if (!worldObj.isRemote && StorageDrawers.config.cache.debugTrace) + FMLLog.log(StorageDrawers.MOD_ID, Level.INFO, "Picked candidate " + lTier1.toString() + " with conv=" + lookupSizeResult); + populateSlot(index++, lTier1, 1); for (int i = 0; i < index - 1; i++) convRate[i] *= lookupSizeResult; @@ -191,6 +198,9 @@ private void populateSlots (ItemStack stack) { ItemStack lTier2 = findLowerTier(lTier1); if (lTier2 != null) { + if (!worldObj.isRemote && StorageDrawers.config.cache.debugTrace) + FMLLog.log(StorageDrawers.MOD_ID, Level.INFO, "Picked candidate " + lTier2.toString() + " with conv=" + lookupSizeResult); + populateSlot(index++, lTier2, 1); for (int i = 0; i < index - 1; i++) convRate[i] *= lookupSizeResult; @@ -212,27 +222,69 @@ private ItemStack findHigherTier (ItemStack stack) { } CraftingManager cm = CraftingManager.getInstance(); + List candidates = new ArrayList(); setupLookup(lookup3, stack); - ItemStack match = cm.findMatchingRecipe(lookup3, worldObj); + List fwdCandidates = findAllMatchingRecipes(lookup3); - if (match == null || match.getItem() == null) { + if (fwdCandidates.size() == 0) { setupLookup(lookup2, stack); - match = cm.findMatchingRecipe(lookup2, worldObj); + fwdCandidates = findAllMatchingRecipes(lookup2); } - if (match != null && match.getItem() != null) { + if (fwdCandidates.size() > 0) { int size = lookupSizeResult; - setupLookup(lookup1, match); - ItemStack comp = cm.findMatchingRecipe(lookup1, worldObj); - if (!DrawerData.areItemsEqual(comp, stack) || comp.stackSize != size) - return null; + for (int i = 0, n1 = fwdCandidates.size(); i < n1; i++) { + ItemStack match = fwdCandidates.get(i); + setupLookup(lookup1, match); + List backCandidates = findAllMatchingRecipes(lookup1); + + for (int j = 0, n2 = backCandidates.size(); j < n2; j++) { + ItemStack comp = backCandidates.get(j); + if (comp.stackSize != size) + continue; + + if (!DrawerData.areItemsEqual(comp, stack, false)) + continue; + + candidates.add(match); + if (!worldObj.isRemote && StorageDrawers.config.cache.debugTrace) + FMLLog.log(StorageDrawers.MOD_ID, Level.INFO, "Found ascending candidate for " + stack.toString() + ": " + match.toString() + " size=" + lookupSizeResult + ", inverse=" + comp.toString()); + + break; + } + } lookupSizeResult = size; } - return match; + ItemStack modMatch = findMatchingModCandidate(stack, candidates); + if (modMatch != null) + return modMatch; + + if (candidates.size() > 0) + return candidates.get(0); + + return null; + } + + private List findAllMatchingRecipes (InventoryCrafting crafting) { + List candidates = new ArrayList(); + + CraftingManager cm = CraftingManager.getInstance(); + List recipeList = cm.getRecipeList(); + + for (int i = 0, n = recipeList.size(); i < n; i++) { + IRecipe recipe = (IRecipe) recipeList.get(i); + if (recipe.matches(crafting, worldObj)) { + ItemStack result = recipe.getCraftingResult(crafting); + if (result != null && result.getItem() != null) + candidates.add(result); + } + } + + return candidates; } private ItemStack findLowerTier (ItemStack stack) { @@ -246,13 +298,14 @@ private ItemStack findLowerTier (ItemStack stack) { List recipeList = cm.getRecipeList(); List candidates = new ArrayList(); + Map candidatesRate = new HashMap(); for (int i = 0, n = recipeList.size(); i < n; i++) { IRecipe recipe = (IRecipe) recipeList.get(i); ItemStack match = null; ItemStack output = recipe.getRecipeOutput(); - if (!DrawerData.areItemsEqual(stack, output)) + if (!DrawerData.areItemsEqual(stack, output, false)) continue; IRecipeHandler handler = StorageDrawers.recipeHandlerRegistry.getRecipeHandler(recipe.getClass()); @@ -275,19 +328,29 @@ private ItemStack findLowerTier (ItemStack stack) { if (match != null) { setupLookup(lookup1, stack); ItemStack comp = cm.findMatchingRecipe(lookup1, worldObj); - if (DrawerData.areItemsEqual(match, comp) && comp.stackSize == recipe.getRecipeSize()) { + if (DrawerData.areItemsEqual(match, comp, false) && comp.stackSize == recipe.getRecipeSize()) { lookupSizeResult = recipe.getRecipeSize(); candidates.add(match); + candidatesRate.put(match, lookupSizeResult); + + if (!worldObj.isRemote && StorageDrawers.config.cache.debugTrace) + FMLLog.log(StorageDrawers.MOD_ID, Level.INFO, "Found descending candidate for " + stack.toString() + ": " + match.toString() + " size=" + lookupSizeResult + ", inverse=" + comp.toString()); } } } ItemStack modMatch = findMatchingModCandidate(stack, candidates); - if (modMatch != null) + if (modMatch != null) { + lookupSizeResult = candidatesRate.get(modMatch); return modMatch; + } - if (candidates.size() > 0) - return candidates.get(0); + if (candidates.size() > 0) { + ItemStack match = candidates.get(0); + lookupSizeResult = candidatesRate.get(match); + + return match; + } return null; } diff --git a/src/com/jaquadro/minecraft/storagedrawers/client/renderer/StorageRenderItem.java b/src/com/jaquadro/minecraft/storagedrawers/client/renderer/StorageRenderItem.java index a70dcc992..56d39b721 100644 --- a/src/com/jaquadro/minecraft/storagedrawers/client/renderer/StorageRenderItem.java +++ b/src/com/jaquadro/minecraft/storagedrawers/client/renderer/StorageRenderItem.java @@ -80,17 +80,26 @@ public void renderItemOverlayIntoGUI (FontRenderer font, ItemStack item, int x, if (item != null) { float scale = .5f; + float xoff = 0; + if (font.getUnicodeFlag()) { + scale = 1f; + xoff = 1; + } if (item.stackSize > 1 || text != null) { - if (item.stackSize >= 10000) - text = (text == null) ? String.format("%.1fK", item.stackSize / 1000f) : text; + if (item.stackSize >= 100000000 || (item.stackSize >= 1000000 && font.getUnicodeFlag())) + text = (text == null) ? String.format("%.0fM", item.stackSize / 1000000f) : text; else if (item.stackSize >= 1000000) text = (text == null) ? String.format("%.1fM", item.stackSize / 1000000f) : text; + else if (item.stackSize >= 100000 || (item.stackSize >= 10000 && font.getUnicodeFlag())) + text = (text == null) ? String.format("%.0fK", item.stackSize / 1000f) : text; + else if (item.stackSize >= 10000) + text = (text == null) ? String.format("%.1fK", item.stackSize / 1000f) : text; else text = (text == null) ? String.valueOf(item.stackSize) : text; - int textX = (int)((x + 16 - font.getStringWidth(text) * scale) / scale) - 1; + int textX = (int)((x + 16 + xoff - font.getStringWidth(text) * scale) / scale) - 1; int textY = (int)((y + 16 - 7 * scale) / scale) - 1; GlStateManager.disableLighting(); diff --git a/src/com/jaquadro/minecraft/storagedrawers/client/renderer/TileEntityDrawersRenderer.java b/src/com/jaquadro/minecraft/storagedrawers/client/renderer/TileEntityDrawersRenderer.java index 77942ea00..62624e4b2 100644 --- a/src/com/jaquadro/minecraft/storagedrawers/client/renderer/TileEntityDrawersRenderer.java +++ b/src/com/jaquadro/minecraft/storagedrawers/client/renderer/TileEntityDrawersRenderer.java @@ -196,7 +196,7 @@ private void renderFastItem (ItemStack itemStack, TileEntityDrawers tile, int sl GlStateManager.pushMatrix(); alignRendering(side); - moveRendering(size, getOffsetXForSide(side, xunit) * 16 - (8 * size), 12.25f - yunit, .999f - depth + 0); // 0 = trimDepth + moveRendering(size, getOffsetXForSide(side, xunit) * 16 - (8 * size), 12.25f - yunit, 1f - depth + 0); // 0 = trimDepth List renderHandlers = StorageDrawers.renderRegistry.getRenderHandlers(); for (int i = 0, n = renderHandlers.size(); i < n; i++) { @@ -204,8 +204,14 @@ private void renderFastItem (ItemStack itemStack, TileEntityDrawers tile, int sl } GlStateManager.disableLighting(); + + GlStateManager.enablePolygonOffset(); + GlStateManager.doPolygonOffset(-1, -1); + renderItem.renderItemIntoGUI(itemStack, 0, 0); + GlStateManager.disablePolygonOffset(); + GlStateManager.popMatrix(); } @@ -242,7 +248,7 @@ private void alignRendering (EnumFacing side) { private void moveRendering (float size, float offsetX, float offsetY, float offsetZ) { GlStateManager.translate(0, 0, offsetZ); - GlStateManager.scale(1 / 16f, 1 / 16f, -.0001f); + GlStateManager.scale(1 / 16f, 1 / 16f, -.00001f); GlStateManager.translate(offsetX, offsetY, 0); GlStateManager.scale(size, size, 1); } @@ -281,10 +287,15 @@ private void renderLock (IBlockState blockState, int side, boolean locked) { double depth = block.isHalfDepth(blockState) ? .5 : 1; TextureAtlasSprite iconLock = Chameleon.instance.iconRegistry.getIcon(StorageDrawers.proxy.iconLockResource); - ChamRender.instance.setRenderBounds(0.46875, 0.9375, 0, 0.53125, 1, depth + .005); + GlStateManager.enablePolygonOffset(); + GlStateManager.doPolygonOffset(-1, -1); + + ChamRender.instance.setRenderBounds(0.46875, 0.9375, 0, 0.53125, 1, depth); ChamRender.instance.state.setRotateTransform(ChamRender.ZPOS, side); ChamRender.instance.renderPartialFace(ChamRender.ZPOS, null, blockState, BlockPos.ORIGIN, iconLock, 0, 0, 1, 1, 1, 1, 1); ChamRender.instance.state.clearRotateTransform(); + + GlStateManager.disablePolygonOffset(); } private void renderVoid (IBlockState blockState, int side, boolean voided) { @@ -296,10 +307,15 @@ private void renderVoid (IBlockState blockState, int side, boolean voided) { double depth = block.isHalfDepth(blockState) ? .5 : 1; TextureAtlasSprite iconVoid = Chameleon.instance.iconRegistry.getIcon(StorageDrawers.proxy.iconVoidResource); - ChamRender.instance.setRenderBounds(1 - .0625, 0.9375, 0, 1, 1, depth + .005); + GlStateManager.enablePolygonOffset(); + GlStateManager.doPolygonOffset(-1, -1); + + ChamRender.instance.setRenderBounds(1 - .0625, 0.9375, 0, 1, 1, depth); ChamRender.instance.state.setRotateTransform(ChamRender.ZPOS, side); ChamRender.instance.renderPartialFace(ChamRender.ZPOS, null, blockState, BlockPos.ORIGIN, iconVoid, 0, 0, 1, 1, 1, 1, 1); ChamRender.instance.state.clearRotateTransform(); + + GlStateManager.disablePolygonOffset(); } private void renderShroud (TileEntityDrawers tile, IBlockState blockState, int side, boolean shrouded) { @@ -317,6 +333,9 @@ private void renderShroud (TileEntityDrawers tile, IBlockState blockState, int s int drawerCount = tile.getDrawerCount(); float size = (drawerCount == 1) ? .25f : .125f; + GlStateManager.enablePolygonOffset(); + GlStateManager.doPolygonOffset(-1, -1); + for (int i = 0; i < count; i++) { IDrawer drawer = tile.getDrawer(i); if (drawer == null || drawer.isEmpty()) @@ -328,11 +347,13 @@ private void renderShroud (TileEntityDrawers tile, IBlockState blockState, int s TextureAtlasSprite iconCover = Chameleon.instance.iconRegistry.getIcon(StorageDrawers.proxy.iconShroudCover); ChamRender.instance.setRenderBounds(xunit - size / 2, (yunit - .25) * unit + size / 2, 0, - xunit - size / 2 + size, (yunit - .25) * unit + size / 2 + size, depth - frontDepth + .005); + xunit - size / 2 + size, (yunit - .25) * unit + size / 2 + size, depth - frontDepth); ChamRender.instance.state.setRotateTransform(ChamRender.ZPOS, side); ChamRender.instance.renderFace(ChamRender.ZPOS, null, blockState, BlockPos.ORIGIN, iconCover, 1, 1, 1); ChamRender.instance.state.clearRotateTransform(); } + + GlStateManager.disablePolygonOffset(); } private void renderIndicator (TileEntityDrawers tile, IBlockState blockState, int side, int level) { @@ -358,15 +379,20 @@ private void renderIndicator (TileEntityDrawers tile, IBlockState blockState, in Area2D statusArea = statusInfo.getSlot(i).getStatusArea(); Area2D activeArea = statusInfo.getSlot(i).getStatusActiveArea(); + GlStateManager.enablePolygonOffset(); + GlStateManager.doPolygonOffset(-1, -1); + ChamRender.instance.setRenderBounds(statusArea.getX() * unit, statusArea.getY() * unit, 0, - (statusArea.getX() + statusArea.getWidth()) * unit, (statusArea.getY() + statusArea.getHeight()) * unit, depth - frontDepth + .005); + (statusArea.getX() + statusArea.getWidth()) * unit, (statusArea.getY() + statusArea.getHeight()) * unit, depth - frontDepth); ChamRender.instance.state.setRotateTransform(ChamRender.ZPOS, side); ChamRender.instance.renderFace(ChamRender.ZPOS, null, blockState, BlockPos.ORIGIN, iconOff, 1, 1, 1); ChamRender.instance.state.clearRotateTransform(); + GlStateManager.doPolygonOffset(-1, -10); + if (level == 1 && drawer.getMaxCapacity() > 0 && drawer.getRemainingCapacity() == 0) { ChamRender.instance.setRenderBounds(statusArea.getX() * unit, statusArea.getY() * unit, 0, - (statusArea.getX() + statusArea.getWidth()) * unit, (statusArea.getY() + statusArea.getHeight()) * unit, depth - frontDepth + .006); + (statusArea.getX() + statusArea.getWidth()) * unit, (statusArea.getY() + statusArea.getHeight()) * unit, depth - frontDepth); ChamRender.instance.state.setRotateTransform(ChamRender.ZPOS, side); ChamRender.instance.renderFace(ChamRender.ZPOS, null, blockState, BlockPos.ORIGIN, iconOn, 1, 1, 1); ChamRender.instance.state.clearRotateTransform(); @@ -388,12 +414,14 @@ else if (level >= 2) { indYCur = Math.min(indYCur, indYEnd); ChamRender.instance.setRenderBounds(indXStart * unit, indYStart * unit, 0, - indXCur * unit, indYCur * unit, depth - frontDepth + .006); + indXCur * unit, indYCur * unit, depth - frontDepth); ChamRender.instance.state.setRotateTransform(ChamRender.ZPOS, side); ChamRender.instance.renderFace(ChamRender.ZPOS, null, blockState, BlockPos.ORIGIN, iconOn, 1, 1, 1); ChamRender.instance.state.clearRotateTransform(); } } + + GlStateManager.disablePolygonOffset(); } } @@ -477,6 +505,9 @@ public void renderItemIntoGUI (FontRenderer fontRenderer, TextureManager texMana if (renderWithColor) GL11.glColor4f(r, g, b, 1.0F); + GL11.glEnable(GL11.GL_POLYGON_OFFSET_FILL); + GL11.glPolygonOffset(-1f, -1); + GL11.glDisable(GL11.GL_LIGHTING); GL11.glEnable(GL11.GL_BLEND); GL11.glEnable(GL11.GL_ALPHA_TEST); @@ -489,9 +520,9 @@ public void renderItemIntoGUI (FontRenderer fontRenderer, TextureManager texMana if (renderEffect && itemStack.hasEffect(i)) renderEffect(texManager, x, y); - } - + GL11.glDisable(GL11.GL_POLYGON_OFFSET_FILL); + } } @Override @@ -577,11 +608,15 @@ private void renderItemIntoGUIBlock (FontRenderer fontRenderer, TextureManager t GL11.glColor4f(r * 1, g * 1, b * 1, 1.0F); GL11.glRotatef(-90, 0, 1, 0); + GL11.glEnable(GL11.GL_POLYGON_OFFSET_FILL); + GL11.glPolygonOffset(-1f, -1f); this.renderBlocksRi.useInventoryTint = this.renderWithColor; this.renderBlocksRi.renderBlockAsItem(block, itemStack.getItemDamage(), 1); this.renderBlocksRi.useInventoryTint = true; + GL11.glDisable(GL11.GL_POLYGON_OFFSET_FILL); + if (block.getRenderBlockPass() == 0) GL11.glAlphaFunc(GL11.GL_GREATER, 0.1F); @@ -836,7 +871,7 @@ private void renderFastItem (ItemStack itemStack, TileEntityDrawers tile, int sl GL11.glPushMatrix(); alignRendering(side); - moveRendering(size, getOffsetXForSide(side, xunit) * 16 - (8 * size), 12.25f - yunit, .999f - depth + block.trimDepth); + moveRendering(size, getOffsetXForSide(side, xunit) * 16 - (8 * size), 12.25f - yunit, 1f - depth + block.trimDepth); List renderHandlers = StorageDrawers.renderRegistry.getRenderHandlers(); for (int i = 0, n = renderHandlers.size(); i < n; i++) { diff --git a/src/com/jaquadro/minecraft/storagedrawers/config/CompTierRegistry.java b/src/com/jaquadro/minecraft/storagedrawers/config/CompTierRegistry.java index de1633943..ff1eb92f2 100644 --- a/src/com/jaquadro/minecraft/storagedrawers/config/CompTierRegistry.java +++ b/src/com/jaquadro/minecraft/storagedrawers/config/CompTierRegistry.java @@ -3,6 +3,7 @@ import net.minecraft.init.Blocks; import net.minecraft.init.Items; import net.minecraft.item.ItemStack; +import net.minecraftforge.fml.common.Loader; import java.util.ArrayList; import java.util.List; @@ -25,7 +26,9 @@ public CompTierRegistry () { register(new ItemStack(Blocks.nether_brick), new ItemStack(Items.netherbrick), 4); register(new ItemStack(Blocks.quartz_block), new ItemStack(Items.quartz), 4); register(new ItemStack(Blocks.melon_block), new ItemStack(Items.melon), 9); - register(new ItemStack(Blocks.sandstone), new ItemStack(Blocks.sand), 4); + + if (!Loader.isModLoaded("ExtraUtilities")) + register(new ItemStack(Blocks.sandstone), new ItemStack(Blocks.sand), 4); } public boolean register (ItemStack upper, ItemStack lower, int convRate) { diff --git a/src/com/jaquadro/minecraft/storagedrawers/config/OreDictRegistry.java b/src/com/jaquadro/minecraft/storagedrawers/config/OreDictRegistry.java index bfa5cd0ea..3cc9c1b6a 100644 --- a/src/com/jaquadro/minecraft/storagedrawers/config/OreDictRegistry.java +++ b/src/com/jaquadro/minecraft/storagedrawers/config/OreDictRegistry.java @@ -51,7 +51,17 @@ public OreDictRegistry () { addBlacklistPrefix("list"); addBlacklistPrefix("dye"); - addWhitelist("nuggetIron"); + for (String item : new String[] { "oreIron", "oreGold", "oreAluminum", "oreAluminium", "oreTin", "oreCopper", "oreLead", "oreSilver", "orePlatinum", "oreNickel" }) + addWhitelist(item); + + for (String item : new String[] { "blockIron", "blockGold", "blockAluminum", "blockAluminium", "blockTin", "blockCopper", "blockLead", "blockSilver", "blockPlatinum", "blockeNickel" }) + addWhitelist(item); + + for (String item : new String[] { "ingotIron", "ingotGold", "ingotAluminum", "ingotAluminium", "ingotTin", "ingotCopper", "ingotLead", "ingotSilver", "ingotPlatinum", "ingotNickel" }) + addWhitelist(item); + + for (String item : new String[] { "nuggetIron", "nuggetGold", "nuggetAluminum", "nuggetAluminium", "nuggetTin", "nuggetCopper", "nuggetLead", "nuggetSilver", "nuggetPlatinum", "nuggetNickel" }) + addWhitelist(item); } public boolean addBlacklist (String entry) { diff --git a/src/com/jaquadro/minecraft/storagedrawers/core/ModRecipes.java b/src/com/jaquadro/minecraft/storagedrawers/core/ModRecipes.java index ae5f9bf8f..5e71bb744 100644 --- a/src/com/jaquadro/minecraft/storagedrawers/core/ModRecipes.java +++ b/src/com/jaquadro/minecraft/storagedrawers/core/ModRecipes.java @@ -32,27 +32,27 @@ public void init () { for (BlockPlanks.EnumType material : BlockPlanks.EnumType.values()) { if (config.isBlockEnabled(EnumBasicDrawer.FULL1.getUnlocalizedName())) { ItemStack result = makeBasicDrawerItemStack(EnumBasicDrawer.FULL1, material.getName(), config.getBlockRecipeOutput(EnumBasicDrawer.FULL1.getUnlocalizedName())); - GameRegistry.addRecipe(result, "xxx", " y ", "xxx", 'x', new ItemStack(Blocks.planks, 1, material.getMetadata()), 'y', Blocks.chest); + GameRegistry.addRecipe(new ShapedOreRecipe(result, "xxx", " y ", "xxx", 'x', new ItemStack(Blocks.planks, 1, material.getMetadata()), 'y', "chestWood")); } if (config.isBlockEnabled(EnumBasicDrawer.FULL2.getUnlocalizedName())) { ItemStack result = makeBasicDrawerItemStack(EnumBasicDrawer.FULL2, material.getName(), config.getBlockRecipeOutput(EnumBasicDrawer.FULL2.getUnlocalizedName())); - GameRegistry.addRecipe(result, "xyx", "xxx", "xyx", 'x', new ItemStack(Blocks.planks, 1, material.getMetadata()), 'y', Blocks.chest); + GameRegistry.addRecipe(new ShapedOreRecipe(result, "xyx", "xxx", "xyx", 'x', new ItemStack(Blocks.planks, 1, material.getMetadata()), 'y', "chestWood")); } if (config.isBlockEnabled(EnumBasicDrawer.FULL4.getUnlocalizedName())) { ItemStack result = makeBasicDrawerItemStack(EnumBasicDrawer.FULL4, material.getName(), config.getBlockRecipeOutput(EnumBasicDrawer.FULL4.getUnlocalizedName())); - GameRegistry.addRecipe(result, "yxy", "xxx", "yxy", 'x', new ItemStack(Blocks.planks, 1, material.getMetadata()), 'y', Blocks.chest); + GameRegistry.addRecipe(new ShapedOreRecipe(result, "yxy", "xxx", "yxy", 'x', new ItemStack(Blocks.planks, 1, material.getMetadata()), 'y', "chestWood")); } if (config.isBlockEnabled(EnumBasicDrawer.HALF2.getUnlocalizedName())) { ItemStack result = makeBasicDrawerItemStack(EnumBasicDrawer.HALF2, material.getName(), config.getBlockRecipeOutput(EnumBasicDrawer.HALF2.getUnlocalizedName())); - GameRegistry.addRecipe(result, "xyx", "xxx", "xyx", 'x', new ItemStack(Blocks.wooden_slab, 1, material.getMetadata()), 'y', Blocks.chest); + GameRegistry.addRecipe(new ShapedOreRecipe(result, "xyx", "xxx", "xyx", 'x', new ItemStack(Blocks.wooden_slab, 1, material.getMetadata()), 'y', "chestWood")); } if (config.isBlockEnabled(EnumBasicDrawer.HALF4.getUnlocalizedName())) { ItemStack result = makeBasicDrawerItemStack(EnumBasicDrawer.HALF4, material.getName(), config.getBlockRecipeOutput(EnumBasicDrawer.HALF4.getUnlocalizedName())); - GameRegistry.addRecipe(result, "yxy", "xxx", "yxy", 'x', new ItemStack(Blocks.wooden_slab, 1, material.getMetadata()), 'y', Blocks.chest); + GameRegistry.addRecipe(new ShapedOreRecipe(result, "yxy", "xxx", "yxy", 'x', new ItemStack(Blocks.wooden_slab, 1, material.getMetadata()), 'y', "chestWood")); } if (config.isBlockEnabled("trim")) { ItemStack result = new ItemStack(ModBlocks.trim, config.getBlockRecipeOutput("trim"), material.getMetadata()); - GameRegistry.addRecipe(result, "xyx", "yyy", "xyx", 'x', Items.stick, 'y', new ItemStack(Blocks.planks, 1, material.getMetadata())); + GameRegistry.addRecipe(new ShapedOreRecipe(result, "xyx", "yyy", "xyx", 'x', "stickWood", 'y', new ItemStack(Blocks.planks, 1, material.getMetadata()))); } } @@ -60,67 +60,67 @@ public void init () { if (config.isBlockEnabled(EnumBasicDrawer.FULL1.getUnlocalizedName())) { ItemStack result = makeBasicDrawerItemStack(EnumBasicDrawer.FULL1, BlockPlanks.EnumType.OAK.getName(), config.getBlockRecipeOutput(EnumBasicDrawer.FULL1.getUnlocalizedName())); - GameRegistry.addRecipe(new ShapedOreRecipe(result, "xxx", " y ", "xxx", 'x', "plankWood", 'y', Blocks.chest)); + GameRegistry.addRecipe(new ShapedOreRecipe(result, "xxx", " y ", "xxx", 'x', "plankWood", 'y', "chestWood")); } if (config.isBlockEnabled(EnumBasicDrawer.FULL2.getUnlocalizedName())) { ItemStack result = makeBasicDrawerItemStack(EnumBasicDrawer.FULL2, BlockPlanks.EnumType.OAK.getName(), config.getBlockRecipeOutput(EnumBasicDrawer.FULL2.getUnlocalizedName())); - GameRegistry.addRecipe(new ShapedOreRecipe(result, "xyx", "xxx", "xyx", 'x', "plankWood", 'y', Blocks.chest)); + GameRegistry.addRecipe(new ShapedOreRecipe(result, "xyx", "xxx", "xyx", 'x', "plankWood", 'y', "chestWood")); } if (config.isBlockEnabled(EnumBasicDrawer.FULL4.getUnlocalizedName())) { ItemStack result = makeBasicDrawerItemStack(EnumBasicDrawer.FULL4, BlockPlanks.EnumType.OAK.getName(), config.getBlockRecipeOutput(EnumBasicDrawer.FULL4.getUnlocalizedName())); - GameRegistry.addRecipe(new ShapedOreRecipe(result, "yxy", "xxx", "yxy", 'x', "plankWood", 'y', Blocks.chest)); + GameRegistry.addRecipe(new ShapedOreRecipe(result, "yxy", "xxx", "yxy", 'x', "plankWood", 'y', "chestWood")); } if (config.isBlockEnabled(EnumBasicDrawer.HALF2.getUnlocalizedName())) { ItemStack result = makeBasicDrawerItemStack(EnumBasicDrawer.HALF2, BlockPlanks.EnumType.OAK.getName(), config.getBlockRecipeOutput(EnumBasicDrawer.HALF2.getUnlocalizedName())); - GameRegistry.addRecipe(new ShapedOreRecipe(result, "xyx", "xxx", "xyx", 'x', "slabWood", 'y', Blocks.chest)); + GameRegistry.addRecipe(new ShapedOreRecipe(result, "xyx", "xxx", "xyx", 'x', "slabWood", 'y', "chestWood")); } if (config.isBlockEnabled(EnumBasicDrawer.HALF4.getUnlocalizedName())) { ItemStack result = makeBasicDrawerItemStack(EnumBasicDrawer.HALF4, BlockPlanks.EnumType.OAK.getName(), config.getBlockRecipeOutput(EnumBasicDrawer.HALF4.getUnlocalizedName())); - GameRegistry.addRecipe(new ShapedOreRecipe(result, "yxy", "xxx", "yxy", 'x', "slabWood", 'y', Blocks.chest)); + GameRegistry.addRecipe(new ShapedOreRecipe(result, "yxy", "xxx", "yxy", 'x', "slabWood", 'y', "chestWood")); } if (config.isBlockEnabled("trim")) { ItemStack result = new ItemStack(ModBlocks.trim, config.getBlockRecipeOutput("trim"), BlockPlanks.EnumType.OAK.getMetadata()); - GameRegistry.addRecipe(new ShapedOreRecipe(result, "xyx", "yyy", "xyx", 'x', Items.stick, 'y', "slabWood")); + GameRegistry.addRecipe(new ShapedOreRecipe(result, "xyx", "yyy", "xyx", 'x', "stickWood", 'y', "slabWood")); } if (config.isBlockEnabled("compdrawers")) - GameRegistry.addRecipe(new ItemStack(ModBlocks.compDrawers, config.getBlockRecipeOutput("compdrawers")), "xxx", "zwz", "xyx", - 'x', new ItemStack(Blocks.stone), 'y', Items.iron_ingot, 'z', new ItemStack(Blocks.piston), 'w', new ItemStack(ModBlocks.basicDrawers, 1, OreDictionary.WILDCARD_VALUE)); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModBlocks.compDrawers, config.getBlockRecipeOutput("compdrawers")), "xxx", "zwz", "xyx", + 'x', new ItemStack(Blocks.stone), 'y', "ingotIron", 'z', new ItemStack(Blocks.piston), 'w', "drawerBasic")); if (config.isBlockEnabled("controller")) - GameRegistry.addRecipe(new ItemStack(ModBlocks.controller), "xxx", "yzy", "xwx", - 'x', new ItemStack(Blocks.stone), 'y', Items.comparator, 'z', new ItemStack(ModBlocks.basicDrawers, 1, OreDictionary.WILDCARD_VALUE), 'w', Items.diamond); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModBlocks.controller), "xxx", "yzy", "xwx", + 'x', new ItemStack(Blocks.stone), 'y', Items.comparator, 'z', "drawerBasic", 'w', "gemDiamond")); if (config.isBlockEnabled("controllerSlave")) - GameRegistry.addRecipe(new ItemStack(ModBlocks.controllerSlave), "xxx", "yzy", "xwx", - 'x', new ItemStack(Blocks.stone), 'y', Items.comparator, 'z', new ItemStack(ModBlocks.basicDrawers, 1, OreDictionary.WILDCARD_VALUE), 'w', Items.gold_ingot); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModBlocks.controllerSlave), "xxx", "yzy", "xwx", + 'x', new ItemStack(Blocks.stone), 'y', Items.comparator, 'z', "drawerBasic", 'w', "ingotGold")); - GameRegistry.addRecipe(new ItemStack(ModItems.upgradeTemplate, 2), "xxx", "xyx", "xxx", - 'x', Items.stick, 'y', new ItemStack(ModBlocks.basicDrawers, 1, OreDictionary.WILDCARD_VALUE)); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.upgradeTemplate, 2), "xxx", "xyx", "xxx", + 'x', "stickWood", 'y', new ItemStack(ModBlocks.basicDrawers, 1, OreDictionary.WILDCARD_VALUE))); if (config.cache.enableStorageUpgrades) { - GameRegistry.addRecipe(new ItemStack(ModItems.upgradeStorage, 1, EnumUpgradeStorage.IRON.getMetadata()), "xyx", "yzy", "xyx", - 'x', Items.iron_ingot, 'y', Items.stick, 'z', ModItems.upgradeTemplate); - GameRegistry.addRecipe(new ItemStack(ModItems.upgradeStorage, 1, EnumUpgradeStorage.GOLD.getMetadata()), "xyx", "yzy", "xyx", - 'x', Items.gold_ingot, 'y', Items.stick, 'z', ModItems.upgradeTemplate); - GameRegistry.addRecipe(new ItemStack(ModItems.upgradeStorage, 1, EnumUpgradeStorage.OBSIDIAN.getMetadata()), "xyx", "yzy", "xyx", - 'x', Blocks.obsidian, 'y', Items.stick, 'z', ModItems.upgradeTemplate); - GameRegistry.addRecipe(new ItemStack(ModItems.upgradeStorage, 1, EnumUpgradeStorage.DIAMOND.getMetadata()), "xyx", "yzy", "xyx", - 'x', Items.diamond, 'y', Items.stick, 'z', ModItems.upgradeTemplate); - GameRegistry.addRecipe(new ItemStack(ModItems.upgradeStorage, 1, EnumUpgradeStorage.EMERALD.getMetadata()), "xyx", "yzy", "xyx", - 'x', Items.emerald, 'y', Items.stick, 'z', ModItems.upgradeTemplate); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.upgradeStorage, 1, EnumUpgradeStorage.IRON.getMetadata()), "xyx", "yzy", "xyx", + 'x', "ingotIron", 'y', "stickWood", 'z', ModItems.upgradeTemplate)); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.upgradeStorage, 1, EnumUpgradeStorage.GOLD.getMetadata()), "xyx", "yzy", "xyx", + 'x', "ingotGold", 'y', "stickWood", 'z', ModItems.upgradeTemplate)); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.upgradeStorage, 1, EnumUpgradeStorage.OBSIDIAN.getMetadata()), "xyx", "yzy", "xyx", + 'x', Blocks.obsidian, 'y', "stickWood", 'z', ModItems.upgradeTemplate)); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.upgradeStorage, 1, EnumUpgradeStorage.DIAMOND.getMetadata()), "xyx", "yzy", "xyx", + 'x', "gemDiamond", 'y', "stickWood", 'z', ModItems.upgradeTemplate)); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.upgradeStorage, 1, EnumUpgradeStorage.EMERALD.getMetadata()), "xyx", "yzy", "xyx", + 'x', "gemEmerald", 'y', "stickWood", 'z', ModItems.upgradeTemplate)); } if (config.cache.enableIndicatorUpgrades) { - GameRegistry.addRecipe(new ItemStack(ModItems.upgradeStatus, 1, EnumUpgradeStatus.LEVEL1.getMetadata()), "wyw", "yzy", "xyx", - 'w', new ItemStack(Blocks.redstone_torch), 'x', Items.redstone, 'y', Items.stick, 'z', ModItems.upgradeTemplate); - GameRegistry.addRecipe(new ItemStack(ModItems.upgradeStatus, 1, EnumUpgradeStatus.LEVEL2.getMetadata()), "wyw", "yzy", "xyx", - 'w', Items.comparator, 'x', Items.redstone, 'y', Items.stick, 'z', ModItems.upgradeTemplate); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.upgradeStatus, 1, EnumUpgradeStatus.LEVEL1.getMetadata()), "wyw", "yzy", "xyx", + 'w', new ItemStack(Blocks.redstone_torch), 'x', "dustRedstone", 'y', "stickWood", 'z', ModItems.upgradeTemplate)); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.upgradeStatus, 1, EnumUpgradeStatus.LEVEL2.getMetadata()), "wyw", "yzy", "xyx", + 'w', Items.comparator, 'x', "dustRedstone", 'y', "stickWood", 'z', ModItems.upgradeTemplate)); } if (config.cache.enableLockUpgrades) { - GameRegistry.addRecipe(new ItemStack(ModItems.drawerKey), "xy ", " y ", " z ", - 'x', Items.gold_nugget, 'y', Items.gold_ingot, 'z', ModItems.upgradeTemplate); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.drawerKey), "xy ", " y ", " z ", + 'x', "nuggetGold", 'y', "ingotGold", 'z', ModItems.upgradeTemplate)); } if (config.cache.enableVoidUpgrades) { diff --git a/src/com/jaquadro/minecraft/storagedrawers/integration/RefinedRelocation.java b/src/com/jaquadro/minecraft/storagedrawers/integration/RefinedRelocation.java index d97922fbd..0424f9988 100644 --- a/src/com/jaquadro/minecraft/storagedrawers/integration/RefinedRelocation.java +++ b/src/com/jaquadro/minecraft/storagedrawers/integration/RefinedRelocation.java @@ -97,7 +97,7 @@ public void postInit () { if (config.isBlockEnabled("compdrawers")) GameRegistry.addRecipe(new ItemStack(compDrawers, 1), "x x", " y ", "x x", - 'x', Items.gold_nugget, 'y', new ItemStack(compDrawers, 1)); + 'x', Items.gold_nugget, 'y', new ItemStack(ModBlocks.compDrawers, 1)); if (config.cache.enableSortingUpgrades) GameRegistry.addRecipe(new ItemStack(upgradeSorting), "y y", " z ", "y y", diff --git a/src/com/jaquadro/minecraft/storagedrawers/integration/Thaumcraft.java b/src/com/jaquadro/minecraft/storagedrawers/integration/Thaumcraft.java index a4b0f1ed9..0d5d448ed 100644 --- a/src/com/jaquadro/minecraft/storagedrawers/integration/Thaumcraft.java +++ b/src/com/jaquadro/minecraft/storagedrawers/integration/Thaumcraft.java @@ -167,6 +167,9 @@ public void render (TileEntity tileEntity, IDrawerGroup drawerGroup, int slot, f GL11.glEnable(GL11.GL_BLEND); GL11.glEnable(GL11.GL_ALPHA_TEST); + GL11.glEnable(GL11.GL_POLYGON_OFFSET_FILL); + GL11.glPolygonOffset(-1f, -1); + ResourceLocation aspectResource = aspect.getImage(); Minecraft.getMinecraft().renderEngine.bindTexture(aspectResource); @@ -178,6 +181,8 @@ public void render (TileEntity tileEntity, IDrawerGroup drawerGroup, int slot, f tessellator.addVertexWithUV(x, y, 0, 0, 0); tessellator.draw(); + GL11.glDisable(GL11.GL_POLYGON_OFFSET_FILL); + GL11.glDisable(GL11.GL_ALPHA_TEST); GL11.glDisable(GL11.GL_BLEND); GL11.glEnable(GL11.GL_LIGHTING); diff --git a/src/com/jaquadro/minecraft/storagedrawers/inventory/InventoryStack.java b/src/com/jaquadro/minecraft/storagedrawers/inventory/InventoryStack.java index bca15e963..e3fb0514d 100644 --- a/src/com/jaquadro/minecraft/storagedrawers/inventory/InventoryStack.java +++ b/src/com/jaquadro/minecraft/storagedrawers/inventory/InventoryStack.java @@ -43,9 +43,10 @@ public void setInStack (ItemStack stack) { applyDiff(stack.stackSize - inCount); } - inStack = stack; + inStack = null; syncInStack(); - syncOutStack(); + + setOutStack(outStack); } private void syncInStack () { diff --git a/src/com/jaquadro/minecraft/storagedrawers/storage/BaseDrawerData.java b/src/com/jaquadro/minecraft/storagedrawers/storage/BaseDrawerData.java index 50fafbcdb..38357e7ff 100644 --- a/src/com/jaquadro/minecraft/storagedrawers/storage/BaseDrawerData.java +++ b/src/com/jaquadro/minecraft/storagedrawers/storage/BaseDrawerData.java @@ -155,6 +155,10 @@ public boolean areItemsEqual (ItemStack item) { } public static boolean areItemsEqual (ItemStack stack1, ItemStack stack2) { + return areItemsEqual(stack1, stack2, true); + } + + public static boolean areItemsEqual (ItemStack stack1, ItemStack stack2, boolean oreDictStrictMode) { if (stack1 == null || stack2 == null) return false; if (stack1.getItem() == null || stack2.getItem() == null) @@ -180,7 +184,7 @@ public static boolean areItemsEqual (ItemStack stack1, ItemStack stack2) { continue; String name = OreDictionary.getOreName(id1); - if (StorageDrawers.oreDictRegistry.isEntryValid(name)) { + if (!oreDictStrictMode || StorageDrawers.oreDictRegistry.isEntryValid(name)) { oreMatch = true; break; }