-
Notifications
You must be signed in to change notification settings - Fork 45
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add an error block, and render it in case of NPE in ISBRH (#658)
* Catch and ignore NPE during ISBRH rendering * Make a fake ErrorBlock * working block for rendering with no registration * More suitable texture for BlockError
- Loading branch information
1 parent
f080941
commit 6c99872
Showing
6 changed files
with
77 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
33 changes: 33 additions & 0 deletions
33
src/main/java/com/gtnewhorizons/angelica/common/BlockError.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
package com.gtnewhorizons.angelica.common; | ||
|
||
import cpw.mods.fml.relauncher.Side; | ||
import cpw.mods.fml.relauncher.SideOnly; | ||
import net.minecraft.block.Block; | ||
import net.minecraft.block.material.Material; | ||
import net.minecraft.client.renderer.texture.IIconRegister; | ||
|
||
/** | ||
* This Block is not actually getting registered. A static instance is created in AngelicaMod. | ||
* In order to register the texture for it, there is a mixin to TextureMap which injects a call | ||
* to this instance's registerBlocKIcons method. Actually registering the block on the client but | ||
* not the server can cause block IDs to different between client/server, which is not good. | ||
* We're essentially injecting the block's texture, so that we may use this block as if it were | ||
* any normal block for rendering purposes with RenderBlocks and such, but not have to actually | ||
* register it as a block. | ||
*/ | ||
|
||
public class BlockError extends Block { | ||
|
||
public BlockError() { | ||
super(Material.rock); | ||
} | ||
|
||
@Override | ||
@SideOnly(Side.CLIENT) | ||
public void registerBlockIcons(IIconRegister reg) | ||
{ | ||
this.blockIcon = reg.registerIcon("angelica:error_block"); | ||
} | ||
|
||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
18 changes: 18 additions & 0 deletions
18
src/mixin/java/com/gtnewhorizons/angelica/mixins/early/angelica/MixinTextureMap.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
package com.gtnewhorizons.angelica.mixins.early.angelica; | ||
|
||
import com.gtnewhorizons.angelica.AngelicaMod; | ||
import net.minecraft.client.renderer.texture.TextureMap; | ||
import org.spongepowered.asm.mixin.Mixin; | ||
import org.spongepowered.asm.mixin.injection.At; | ||
import org.spongepowered.asm.mixin.injection.Inject; | ||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; | ||
|
||
@Mixin(TextureMap.class) | ||
public class MixinTextureMap { | ||
|
||
@Inject(method = "registerIcons", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/Minecraft;getMinecraft()Lnet/minecraft/client/Minecraft;")) | ||
private void angelica$registerErrorBlockIcon(CallbackInfo ci) { | ||
TextureMap thisObject = (TextureMap)(Object)this; | ||
AngelicaMod.blockError.registerBlockIcons(thisObject); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters