BuildCraft 6.3.3

This commit is contained in:
asiekierka 2015-01-23 09:18:07 +01:00
parent f8ae10e2f2
commit 3fca102985
7 changed files with 29 additions and 19 deletions

View file

@ -22,7 +22,7 @@ apply plugin: 'forge' // adds the forge dependency
apply plugin: 'maven' // for uploading to a maven repo apply plugin: 'maven' // for uploading to a maven repo
apply plugin: 'checkstyle' apply plugin: 'checkstyle'
version = "6.3.2" version = "6.3.3"
group= "com.mod-buildcraft" group= "com.mod-buildcraft"
archivesBaseName = "buildcraft" // the name that all artifacts will use as a base. artifacts names follow this pattern: [baseName]-[appendix]-[version]-[classifier].[extension] archivesBaseName = "buildcraft" // the name that all artifacts will use as a base. artifacts names follow this pattern: [baseName]-[appendix]-[version]-[classifier].[extension]

View file

@ -0,0 +1,4 @@
Bugfixes:
[#2407] Crash with blocks NPEing on getSubBlocks (asie)
Crash with null-block facades and/or pipe plugs (asie)
Removed facade debug code (asie)

View file

@ -1,3 +1,3 @@
1.6.4:BuildCraft:4.2.2 1.6.4:BuildCraft:4.2.2
1.7.2:BuildCraft:6.0.16 1.7.2:BuildCraft:6.0.16
1.7.10:BuildCraft:6.3.2 1.7.10:BuildCraft:6.3.3

View file

@ -242,6 +242,7 @@ public class ItemFacade extends ItemBuildCraft implements IFacadeItem, IPipePlug
private void registerValidFacades(Block block, Item item) { private void registerValidFacades(Block block, Item item) {
ArrayList<ItemStack> stacks = new ArrayList<ItemStack>(16); ArrayList<ItemStack> stacks = new ArrayList<ItemStack>(16);
try {
if (FMLCommonHandler.instance().getEffectiveSide() == Side.CLIENT) { if (FMLCommonHandler.instance().getEffectiveSide() == Side.CLIENT) {
for (CreativeTabs ct : item.getCreativeTabs()) { for (CreativeTabs ct : item.getCreativeTabs()) {
block.getSubBlocks(item, ct, stacks); block.getSubBlocks(item, ct, stacks);
@ -251,6 +252,9 @@ public class ItemFacade extends ItemBuildCraft implements IFacadeItem, IPipePlug
stacks.add(new ItemStack(item, 1, i)); stacks.add(new ItemStack(item, 1, i));
} }
} }
} catch (Exception e) {
e.printStackTrace();
}
for (ItemStack stack : stacks) { for (ItemStack stack : stacks) {
try { try {
int i = stack.getItemDamage(); int i = stack.getItemDamage();

View file

@ -22,12 +22,12 @@ public class FacadeBlockAccess implements IBlockAccess {
@Override @Override
public Block getBlock(int x, int y, int z) { public Block getBlock(int x, int y, int z) {
System.out.println("Querying block at " + x + ", " + y + ", " + z); //System.out.println("Querying block at " + x + ", " + y + ", " + z);
TileEntity tile = world.getTileEntity(x, y, z); TileEntity tile = world.getTileEntity(x, y, z);
if (tile instanceof TileGenericPipe) { if (tile instanceof TileGenericPipe) {
PipePluggable p = ((TileGenericPipe) tile).getPipePluggable(side); PipePluggable p = ((TileGenericPipe) tile).getPipePluggable(side);
if (p instanceof FacadePluggable) { if (p instanceof FacadePluggable) {
System.out.println("Found facade"); //System.out.println("Found facade");
return ((FacadePluggable) p).getRenderingBlock(); return ((FacadePluggable) p).getRenderingBlock();
} }
} }
@ -46,12 +46,12 @@ public class FacadeBlockAccess implements IBlockAccess {
@Override @Override
public int getBlockMetadata(int x, int y, int z) { public int getBlockMetadata(int x, int y, int z) {
System.out.println("Querying block metadata at " + x + ", " + y + ", " + z); //System.out.println("Querying block metadata at " + x + ", " + y + ", " + z);
TileEntity tile = world.getTileEntity(x, y, z); TileEntity tile = world.getTileEntity(x, y, z);
if (tile instanceof TileGenericPipe) { if (tile instanceof TileGenericPipe) {
PipePluggable p = ((TileGenericPipe) tile).getPipePluggable(side); PipePluggable p = ((TileGenericPipe) tile).getPipePluggable(side);
if (p instanceof FacadePluggable) { if (p instanceof FacadePluggable) {
System.out.println("Found facade " + ((FacadePluggable) p).getRenderingMeta()); //System.out.println("Found facade " + ((FacadePluggable) p).getRenderingMeta());
return ((FacadePluggable) p).getRenderingMeta(); return ((FacadePluggable) p).getRenderingMeta();
} }
} }

View file

@ -158,13 +158,16 @@ public class FacadeItemRenderer implements IItemRenderer {
GL11.glPushMatrix(); GL11.glPushMatrix();
// Enable glBlending for transparency // Enable glBlending for transparency
if (block != null && block.getRenderBlockPass() > 0) { if (block != null) {
if (block.getRenderBlockPass() > 0) {
GL11.glAlphaFunc(GL11.GL_GREATER, 0.1F); GL11.glAlphaFunc(GL11.GL_GREATER, 0.1F);
GL11.glEnable(GL11.GL_BLEND); GL11.glEnable(GL11.GL_BLEND);
OpenGlHelper.glBlendFunc(770, 771, 1, 0); OpenGlHelper.glBlendFunc(770, 771, 1, 0);
} }
RenderUtils.setGLColorFromInt(block.getRenderColor(decodedMeta)); RenderUtils.setGLColorFromInt(block.getRenderColor(decodedMeta));
}
if (hollow) { if (hollow) {
GL11.glTranslatef(translateX, translateY, translateZ); GL11.glTranslatef(translateX, translateY, translateZ);
drawHollowCube(tessellator, render, block, decodedMeta); drawHollowCube(tessellator, render, block, decodedMeta);

View file

@ -21,7 +21,6 @@ import net.minecraftforge.common.util.ForgeDirection;
import buildcraft.api.core.render.ITextureStates; import buildcraft.api.core.render.ITextureStates;
import buildcraft.transport.BlockGenericPipe; import buildcraft.transport.BlockGenericPipe;
/* /*
* This is fake block to render pluggables and pipes without altering host state * This is fake block to render pluggables and pipes without altering host state
* May prove useful if we will make API for roboports, pipes, plugs and facades * May prove useful if we will make API for roboports, pipes, plugs and facades