Jump to content

[1.8] Crafting Crash


AsterAether

Recommended Posts

Hey Guys,

 

When I try to craft an item from my mod, it has no texture in the table.

When i mouse over, it crashes:

 

[19:59:19] [main/INFO] [GradleStart]: Extra: []

[19:59:19] [main/INFO] [GradleStart]: Running with arguments: [--userProperties, {}, --assetsDir, C:/Users/tommi_000/.gradle/caches/minecraft/assets, --assetIndex, 1.8, --accessToken, {REDACTED}, --version, 1.8, --tweakClass, net.minecraftforge.fml.common.launcher.FMLTweaker, --tweakClass, net.minecraftforge.gradle.tweakers.CoremodTweaker]

[19:59:19] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.fml.common.launcher.FMLTweaker

[19:59:19] [main/INFO] [LaunchWrapper]: Using primary tweak class name net.minecraftforge.fml.common.launcher.FMLTweaker

[19:59:19] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.gradle.tweakers.CoremodTweaker

[19:59:19] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLTweaker

[19:59:19] [main/INFO] [FML]: Forge Mod Loader version 8.0.76.1375 for Minecraft 1.8 loading

[19:59:19] [main/INFO] [FML]: Java is Java HotSpot 64-Bit Server VM, version 1.8.0_40, running on Windows 8.1:amd64:6.3, installed at C:\Program Files\Java\jre1.8.0_40

[19:59:19] [main/INFO] [FML]: Managed to load a deobfuscated Minecraft name- we are in a deobfuscated environment. Skipping runtime deobfuscation

[19:59:19] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.gradle.tweakers.CoremodTweaker

[19:59:19] [main/INFO] [GradleStart]: Injecting location in coremod net.minecraftforge.fml.relauncher.FMLCorePlugin

[19:59:19] [main/INFO] [GradleStart]: Injecting location in coremod net.minecraftforge.classloading.FMLForgePlugin

[19:59:19] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.fml.common.launcher.FMLInjectionAndSortingTweaker

[19:59:19] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.fml.common.launcher.FMLDeobfTweaker

[19:59:19] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.gradle.tweakers.AccessTransformerTweaker

[19:59:19] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLInjectionAndSortingTweaker

[19:59:19] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLInjectionAndSortingTweaker

[19:59:19] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.relauncher.CoreModManager$FMLPluginWrapper

[19:59:20] [main/ERROR] [FML]: The binary patch set is missing. Either you are in a development environment, or things are not going to work!

[19:59:22] [main/ERROR] [FML]: FML appears to be missing any signature data. This is not a good thing

[19:59:22] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.relauncher.CoreModManager$FMLPluginWrapper

[19:59:22] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLDeobfTweaker

[19:59:22] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.gradle.tweakers.AccessTransformerTweaker

[19:59:22] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.fml.common.launcher.TerminalTweaker

[19:59:22] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.TerminalTweaker

[19:59:22] [main/INFO] [LaunchWrapper]: Launching wrapped minecraft {net.minecraft.client.main.Main}

[19:59:23] [Client thread/INFO]: Setting user: Player583

[19:59:25] [Client thread/INFO]: LWJGL Version: 2.9.1

[19:59:26] [Client thread/INFO] [MinecraftForge]: Attempting early MinecraftForge initialization

[19:59:26] [Client thread/INFO] [FML]: MinecraftForge v11.14.1.1375 Initialized

[19:59:26] [Client thread/INFO] [FML]: Replaced 204 ore recipies

[19:59:26] [Client thread/INFO] [FML]: Preloading CrashReport classes

[19:59:26] [Client thread/INFO] [MinecraftForge]: Completed early MinecraftForge initialization

[19:59:26] [Client thread/INFO] [FML]: Searching D:\ForgeModding\Mods\BaseExample\mods for mods

[19:59:27] [Client thread/INFO] [FML]: Forge Mod Loader has identified 5 mods to load

[19:59:28] [Client thread/INFO] [FML]: Attempting connection with missing mods [mcp, FML, Forge, baseexample, baselib] at CLIENT

[19:59:28] [Client thread/INFO] [FML]: Attempting connection with missing mods [mcp, FML, Forge, baseexample, baselib] at SERVER

[19:59:28] [Client thread/INFO]: Reloading ResourceManager: Default, FMLFileResourcePack:Forge Mod Loader, FMLFileResourcePack:Minecraft Forge, FMLFileResourcePack:Tom´s Mod, FMLFileResourcePack:Tom´s Mod

[19:59:28] [Client thread/INFO] [FML]: Processing ObjectHolder annotations

[19:59:28] [Client thread/INFO] [FML]: Found 384 ObjectHolder annotations

[19:59:28] [Client thread/INFO] [FML]: Configured a dormant chunk cache size of 0

[19:59:28] [Client thread/INFO] [FML]: Applying holder lookups

[19:59:28] [Client thread/INFO] [FML]: Holder lookups applied

[19:59:28] [sound Library Loader/INFO]: Starting up SoundSystem...

[19:59:29] [Thread-7/INFO]: Initializing LWJGL OpenAL

[19:59:29] [Thread-7/INFO]: (The LWJGL binding of OpenAL.  For more information, see http://www.lwjgl.org)

[19:59:29] [Thread-7/INFO]: OpenAL initialized.

[19:59:29] [sound Library Loader/INFO]: Sound engine started

[19:59:32] [Client thread/INFO]: Created: 512x512 textures-atlas

[19:59:33] [Client thread/INFO] [FML]: Forge Mod Loader has successfully loaded 5 mods

[19:59:33] [Client thread/INFO]: Reloading ResourceManager: Default, FMLFileResourcePack:Forge Mod Loader, FMLFileResourcePack:Minecraft Forge, FMLFileResourcePack:Tom´s Mod, FMLFileResourcePack:Tom´s Mod

[19:59:33] [Client thread/INFO]: SoundSystem shutting down...

[19:59:33] [Client thread/WARN]: Author: Paul Lamb, www.paulscode.com

[19:59:33] [sound Library Loader/INFO]: Starting up SoundSystem...

[19:59:33] [Thread-9/INFO]: Initializing LWJGL OpenAL

[19:59:33] [Thread-9/INFO]: (The LWJGL binding of OpenAL.  For more information, see http://www.lwjgl.org)

[19:59:33] [Thread-9/INFO]: OpenAL initialized.

[19:59:34] [sound Library Loader/INFO]: Sound engine started

[19:59:35] [Client thread/INFO]: Created: 512x512 textures-atlas

[19:59:51] [server thread/INFO]: Starting integrated minecraft server version 1.8

[19:59:51] [server thread/INFO]: Generating keypair

[19:59:51] [server thread/INFO] [FML]: Injecting existing block and item data into this server instance

[19:59:51] [server thread/INFO] [FML]: Applying holder lookups

[19:59:51] [server thread/INFO] [FML]: Holder lookups applied

[19:59:51] [server thread/INFO] [FML]: Loading dimension 0 (New World) (net.minecraft.server.integrated.IntegratedServer@5cf3d83f)

[19:59:51] [server thread/INFO] [FML]: Loading dimension 1 (New World) (net.minecraft.server.integrated.IntegratedServer@5cf3d83f)

[19:59:51] [server thread/INFO] [FML]: Loading dimension -1 (New World) (net.minecraft.server.integrated.IntegratedServer@5cf3d83f)

[19:59:51] [server thread/INFO]: Preparing start region for level 0

[19:59:52] [server thread/INFO]: Changing view distance to 12, from 10

[19:59:52] [Netty Local Client IO #0/INFO] [FML]: Server protocol version 2

[19:59:52] [Netty Server IO #1/INFO] [FML]: Client protocol version 2

[19:59:52] [Netty Server IO #1/INFO] [FML]: Client attempting to join with 5 mods : baseexample@DEV-1.0,FML@8.0.76.1375,baselib@DEV-0.1,Forge@11.14.1.1375,mcp@9.05

[19:59:52] [server thread/INFO] [FML]: [server thread] Server side modded connection established

[19:59:52] [Netty Local Client IO #0/INFO] [FML]: [Netty Local Client IO #0] Client side modded connection established

[19:59:52] [server thread/INFO]: Player583[local:E:2a1ace56] logged in with entity id 149 at (-660.64811880176, 4.0, -733.6958431089894)

[19:59:52] [server thread/INFO]: Player583 joined the game

[19:59:59] [server thread/INFO]: Stopping server

[19:59:59] [server thread/INFO]: Saving players

[19:59:59] [server thread/INFO]: Saving worlds

[19:59:59] [server thread/INFO]: Saving chunks for level 'New World'/Overworld

[19:59:59] [server thread/INFO]: Saving chunks for level 'New World'/Nether

[19:59:59] [server thread/INFO]: Saving chunks for level 'New World'/The End

[19:59:59] [server thread/INFO] [FML]: Unloading dimension 0

[19:59:59] [server thread/INFO] [FML]: Unloading dimension -1

[19:59:59] [server thread/INFO] [FML]: Unloading dimension 1

[19:59:59] [server thread/INFO] [FML]: Applying holder lookups

[19:59:59] [server thread/INFO] [FML]: Holder lookups applied

[20:00:00] [Client thread/FATAL]: Reported exception thrown!

net.minecraft.util.ReportedException: Rendering screen

at net.minecraft.client.renderer.EntityRenderer.updateCameraAndRender(EntityRenderer.java:1164) ~[EntityRenderer.class:?]

at net.minecraft.client.Minecraft.runGameLoop(Minecraft.java:1107) ~[Minecraft.class:?]

at net.minecraft.client.Minecraft.run(Minecraft.java:376) [Minecraft.class:?]

at net.minecraft.client.main.Main.main(Main.java:117) [Main.class:?]

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.8.0_40]

at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) ~[?:1.8.0_40]

at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) ~[?:1.8.0_40]

at java.lang.reflect.Method.invoke(Unknown Source) ~[?:1.8.0_40]

at net.minecraft.launchwrapper.Launch.launch(Launch.java:135) [launchwrapper-1.11.jar:?]

at net.minecraft.launchwrapper.Launch.main(Launch.java:28) [launchwrapper-1.11.jar:?]

at net.minecraftforge.gradle.GradleStartCommon.launch(Unknown Source) [start/:?]

at GradleStart.main(Unknown Source) [start/:?]

Caused by: java.lang.NullPointerException

at net.minecraft.item.ItemStack.getTooltip(ItemStack.java:872) ~[itemStack.class:?]

at net.minecraft.client.gui.GuiScreen.renderToolTip(GuiScreen.java:163) ~[GuiScreen.class:?]

at net.minecraft.client.gui.inventory.GuiContainer.drawScreen(GuiContainer.java:186) ~[GuiContainer.class:?]

at net.minecraftforge.client.ForgeHooksClient.drawScreen(ForgeHooksClient.java:462) ~[ForgeHooksClient.class:?]

at net.minecraft.client.renderer.EntityRenderer.updateCameraAndRender(EntityRenderer.java:1134) ~[EntityRenderer.class:?]

... 11 more

[20:00:00] [Client thread/INFO] [sTDOUT]: [net.minecraft.init.Bootstrap:printToSYSOUT:660]: ---- Minecraft Crash Report ----

// You're mean.

 

Time: 22.04.15 20:00

Description: Rendering screen

 

java.lang.NullPointerException: Rendering screen

at net.minecraft.item.ItemStack.getTooltip(ItemStack.java:872)

at net.minecraft.client.gui.GuiScreen.renderToolTip(GuiScreen.java:163)

at net.minecraft.client.gui.inventory.GuiContainer.drawScreen(GuiContainer.java:186)

at net.minecraftforge.client.ForgeHooksClient.drawScreen(ForgeHooksClient.java:462)

at net.minecraft.client.renderer.EntityRenderer.updateCameraAndRender(EntityRenderer.java:1134)

at net.minecraft.client.Minecraft.runGameLoop(Minecraft.java:1107)

at net.minecraft.client.Minecraft.run(Minecraft.java:376)

at net.minecraft.client.main.Main.main(Main.java:117)

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)

at java.lang.reflect.Method.invoke(Unknown Source)

at net.minecraft.launchwrapper.Launch.launch(Launch.java:135)

at net.minecraft.launchwrapper.Launch.main(Launch.java:28)

at net.minecraftforge.gradle.GradleStartCommon.launch(Unknown Source)

at GradleStart.main(Unknown Source)

 

 

A detailed walkthrough of the error, its code path and all known details is as follows:

---------------------------------------------------------------------------------------

 

-- Head --

Stacktrace:

at net.minecraft.item.ItemStack.getTooltip(ItemStack.java:872)

at net.minecraft.client.gui.GuiScreen.renderToolTip(GuiScreen.java:163)

at net.minecraft.client.gui.inventory.GuiContainer.drawScreen(GuiContainer.java:186)

at net.minecraftforge.client.ForgeHooksClient.drawScreen(ForgeHooksClient.java:462)

 

-- Screen render details --

Details:

Screen name: net.minecraft.client.gui.inventory.GuiCrafting

Mouse location: Scaled: (253, 73). Absolute: (506, 333)

Screen size: Scaled: (427, 240). Absolute: (854, 480). Scale factor of 2

 

-- Affected level --

Details:

Level name: MpServer

All players: 1 total; [EntityPlayerSP['Player583'/149, l='MpServer', x=-660,65, y=4,00, z=-733,70]]

Chunk stats: MultiplayerChunkCache: 625, 625

Level seed: 0

Level generator: ID 01 - flat, ver 0. Features enabled: false

Level generator options:

Level spawn location: -593,00,4,00,-792,00 - World: (-593,4,-792), Chunk: (at 15,0,8 in -38,-50; contains blocks -608,0,-800 to -593,255,-785), Region: (-2,-2; contains chunks -64,-64 to -33,-33, blocks -1024,0,-1024 to -513,255,-513)

Level time: 84662 game time, 1000 day time

Level dimension: 0

Level storage version: 0x00000 - Unknown?

Level weather: Rain time: 0 (now: true), thunder time: 0 (now: false)

Level game mode: Game mode: creative (ID 1). Hardcore: false. Cheats: false

Forced entities: 94 total; [EntitySlime['Slime'/1, l='MpServer', x=-740,53, y=4,00, z=-694,19], EntitySlime['Slime'/9, l='MpServer', x=-715,22, y=4,00, z=-754,63], EntitySlime['Slime'/10, l='MpServer', x=-722,90, y=4,32, z=-727,82], EntitySlime['Slime'/11, l='MpServer', x=-717,81, y=4,00, z=-704,59], EntitySlime['Slime'/12, l='MpServer', x=-729,88, y=4,00, z=-675,38], EntitySlime['Slime'/13, l='MpServer', x=-736,47, y=4,02, z=-659,03], EntitySlime['Slime'/14, l='MpServer', x=-731,72, y=4,02, z=-665,50], EntitySlime['Slime'/15, l='MpServer', x=-722,51, y=4,01, z=-670,31], EntitySlime['Slime'/16, l='MpServer', x=-722,66, y=4,02, z=-657,81], EntitySlime['Slime'/17, l='MpServer', x=-721,40, y=4,32, z=-653,00], EntitySlime['Slime'/21, l='MpServer', x=-713,78, y=4,00, z=-773,13], EntityItem['item.item.wheat'/22, l='MpServer', x=-705,69, y=5,00, z=-723,22], EntityItem['item.item.seeds'/23, l='MpServer', x=-705,69, y=5,00, z=-723,94], EntityItem['item.item.potato'/24, l='MpServer', x=-707,66, y=5,00, z=-720,84], EntityItem['item.item.wheat'/25, l='MpServer', x=-711,00, y=5,00, z=-724,06], EntityItem['item.item.seeds'/26, l='MpServer', x=-711,81, y=5,00, z=-723,44], EntityItem['item.item.wheat'/27, l='MpServer', x=-712,81, y=5,00, z=-723,84], EntityItem['item.item.seeds'/28, l='MpServer', x=-710,53, y=5,00, z=-722,97], EntityItem['item.item.potato'/29, l='MpServer', x=-708,97, y=5,00, z=-719,44], EntitySlime['Slime'/30, l='MpServer', x=-720,09, y=4,00, z=-691,75], EntitySlime['Slime'/31, l='MpServer', x=-713,13, y=4,01, z=-679,96], EntitySlime['Slime'/32, l='MpServer', x=-718,28, y=4,00, z=-672,38], EntitySlime['Slime'/33, l='MpServer', x=-721,96, y=4,67, z=-659,07], EntitySlime['Slime'/40, l='MpServer', x=-689,33, y=5,16, z=-746,02], EntityItem['item.item.wheat'/41, l='MpServer', x=-691,59, y=5,00, z=-706,66], EntitySlime['Slime'/42, l='MpServer', x=-691,94, y=5,02, z=-709,84], EntityItem['item.item.potato'/43, l='MpServer', x=-698,78, y=5,00, z=-717,53], EntityItem['item.item.carrots'/44, l='MpServer', x=-696,69, y=5,00, z=-712,19], EntityItem['item.item.seeds'/45, l='MpServer', x=-690,50, y=5,00, z=-707,34], EntityVillager['Villager'/46, l='MpServer', x=-690,75, y=4,00, z=-700,50], EntityItem['item.item.seeds'/47, l='MpServer', x=-692,72, y=4,00, z=-696,00], EntityItem['item.item.potato'/48, l='MpServer', x=-696,38, y=5,00, z=-691,16], EntitySlime['Slime'/49, l='MpServer', x=-700,74, y=4,70, z=-680,05], EntitySlime['Slime'/50, l='MpServer', x=-704,69, y=4,00, z=-667,13], EntitySlime['Slime'/51, l='MpServer', x=-688,32, y=5,07, z=-663,65], EntitySlime['Slime'/52, l='MpServer', x=-699,96, y=4,53, z=-657,69], EntitySlime['Slime'/58, l='MpServer', x=-678,60, y=4,52, z=-785,39], EntitySlime['Slime'/59, l='MpServer', x=-683,34, y=4,00, z=-751,13], EntitySlime['Slime'/60, l='MpServer', x=-674,03, y=4,00, z=-723,92], EntitySlime['Slime'/61, l='MpServer', x=-685,84, y=4,02, z=-736,53], EntityItem['item.item.wheat'/62, l='MpServer', x=-688,00, y=5,00, z=-704,28], EntityItem['item.item.seeds'/63, l='MpServer', x=-687,47, y=5,00, z=-705,28], EntityItem['item.item.seeds'/64, l='MpServer', x=-687,84, y=5,00, z=-708,16], EntitySlime['Slime'/65, l='MpServer', x=-681,16, y=4,00, z=-713,69], EntityVillager['Villager'/66, l='MpServer', x=-674,78, y=4,00, z=-699,88], EntityVillager['Villager'/67, l='MpServer', x=-679,28, y=4,00, z=-696,75], EntityVillager['Villager'/68, l='MpServer', x=-684,34, y=5,00, z=-695,75], EntityVillager['Villager'/69, l='MpServer', x=-680,44, y=4,00, z=-700,82], EntityVillager['Villager'/70, l='MpServer', x=-672,94, y=5,50, z=-667,53], EntitySlime['Slime'/71, l='MpServer', x=-670,91, y=4,00, z=-660,00], EntitySlime['Slime'/1736, l='MpServer', x=-729,28, y=4,00, z=-732,88], EntitySlime['Slime'/74, l='MpServer', x=-669,51, y=4,01, z=-794,91], EntitySlime['Slime'/75, l='MpServer', x=-670,64, y=4,14, z=-799,98], EntitySlime['Slime'/76, l='MpServer', x=-654,47, y=4,02, z=-720,50], EntitySlime['Slime'/79, l='MpServer', x=-669,59, y=4,01, z=-730,66], EntityItem['item.item.potato'/80, l='MpServer', x=-660,59, y=4,00, z=-716,88], EntityItem['item.item.potato'/81, l='MpServer', x=-658,63, y=5,00, z=-715,75], EntityItem['item.item.seeds'/82, l='MpServer', x=-658,78, y=5,00, z=-717,72], EntityItem['item.item.potato'/83, l='MpServer', x=-664,13, y=5,00, z=-715,16], EntityItem['item.item.potato'/84, l='MpServer', x=-662,19, y=5,00, z=-714,19], EntityItem['item.item.wheat'/85, l='MpServer', x=-663,59, y=5,00, z=-718,03], EntityItem['item.item.wheat'/86, l='MpServer', x=-659,13, y=5,00, z=-717,16], EntityItem['item.item.seeds'/87, l='MpServer', x=-663,69, y=5,00, z=-718,66], EntityItem['item.item.potato'/88, l='MpServer', x=-660,09, y=5,00, z=-714,41], EntityItem['item.item.potato'/89, l='MpServer', x=-661,06, y=5,00, z=-714,72], EntityItem['item.item.potato'/90, l='MpServer', x=-658,44, y=5,00, z=-714,69], EntitySlime['Slime'/91, l='MpServer', x=-662,53, y=3,91, z=-709,16], EntityVillager['Villager'/92, l='MpServer', x=-670,63, y=4,00, z=-696,59], EntitySkeleton['Skeleton'/93, l='MpServer', x=-660,50, y=5,00, z=-692,50], EntityVillager['Villager'/94, l='MpServer', x=-670,59, y=4,00, z=-694,84], EntityVillager['Villager'/95, l='MpServer', x=-670,56, y=5,00, z=-675,88], EntityVillager['Villager'/96, l='MpServer', x=-664,38, y=4,00, z=-667,69], EntitySlime['Slime'/98, l='MpServer', x=-644,28, y=4,00, z=-807,19], EntitySlime['Slime'/99, l='MpServer', x=-649,31, y=4,00, z=-811,88], EntitySlime['Slime'/100, l='MpServer', x=-640,84, y=4,02, z=-807,88], EntitySlime['Slime'/101, l='MpServer', x=-639,10, y=4,53, z=-711,15], EntitySkeleton['Skeleton'/102, l='MpServer', x=-647,50, y=5,00, z=-694,50], EntitySlime['Slime'/105, l='MpServer', x=-639,88, y=4,67, z=-803,25], EntitySlime['Slime'/106, l='MpServer', x=-642,27, y=5,15, z=-801,67], EntitySlime['Slime'/108, l='MpServer', x=-627,64, y=4,52, z=-798,90], EntitySheep['Sheep'/109, l='MpServer', x=-625,19, y=4,00, z=-791,84], EntityPig['Pig'/110, l='MpServer', x=-627,38, y=4,00, z=-767,91], EntitySlime['Slime'/111, l='MpServer', x=-630,72, y=4,00, z=-702,66], EntityPig['Pig'/112, l='MpServer', x=-624,63, y=4,00, z=-693,91], EntityRabbit['Rabbit'/115, l='MpServer', x=-617,63, y=4,00, z=-783,00], EntitySlime['Slime'/116, l='MpServer', x=-620,09, y=4,02, z=-755,13], EntityPig['Pig'/117, l='MpServer', x=-613,91, y=4,00, z=-712,03], EntitySlime['Slime'/119, l='MpServer', x=-601,99, y=5,16, z=-705,28], EntityPig['Pig'/122, l='MpServer', x=-582,41, y=4,00, z=-721,13], EntitySlime['Slime'/123, l='MpServer', x=-588,05, y=5,16, z=-715,41], EntitySlime['Slime'/125, l='MpServer', x=-580,72, y=4,00, z=-696,25], EntityPlayerSP['Player583'/149, l='MpServer', x=-660,65, y=4,00, z=-733,70], EntitySlime['Slime'/126, l='MpServer', x=-586,22, y=4,02, z=-687,91], EntitySlime['Slime'/127, l='MpServer', x=-583,80, y=4,67, z=-685,91]]

Retry entities: 0 total; []

Server brand: fml,forge

Server type: Integrated singleplayer server

Stacktrace:

at net.minecraft.client.multiplayer.WorldClient.addWorldInfoToCrashReport(WorldClient.java:392)

at net.minecraft.client.Minecraft.addGraphicsAndWorldToCrashReport(Minecraft.java:2600)

at net.minecraft.client.Minecraft.run(Minecraft.java:398)

at net.minecraft.client.main.Main.main(Main.java:117)

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)

at java.lang.reflect.Method.invoke(Unknown Source)

at net.minecraft.launchwrapper.Launch.launch(Launch.java:135)

at net.minecraft.launchwrapper.Launch.main(Launch.java:28)

at net.minecraftforge.gradle.GradleStartCommon.launch(Unknown Source)

at GradleStart.main(Unknown Source)

 

-- System Details --

Details:

Minecraft Version: 1.8

Operating System: Windows 8.1 (amd64) version 6.3

Java Version: 1.8.0_40, Oracle Corporation

Java VM Version: Java HotSpot 64-Bit Server VM (mixed mode), Oracle Corporation

Memory: 246330192 bytes (234 MB) / 782761984 bytes (746 MB) up to 3817865216 bytes (3641 MB)

JVM Flags: 0 total;

IntCache: cache: 0, tcache: 0, allocated: 0, tallocated: 0

FML: MCP v9.10 FML v8.0.76.1375 Minecraft Forge 11.14.1.1375 5 mods loaded, 5 mods active

mcp{9.05} [Minecraft Coder Pack] (minecraft.jar) Unloaded->Constructed->Pre-initialized->Initialized->Post-initialized->Available->Available->Available->Available

FML{8.0.76.1375} [Forge Mod Loader] (forgeSrc-1.8-11.14.1.1375.jar) Unloaded->Constructed->Pre-initialized->Initialized->Post-initialized->Available->Available->Available->Available

Forge{11.14.1.1375} [Minecraft Forge] (forgeSrc-1.8-11.14.1.1375.jar) Unloaded->Constructed->Pre-initialized->Initialized->Post-initialized->Available->Available->Available->Available

baselib{DEV-0.1} [Tom´s Mod] (bin) Unloaded->Constructed->Pre-initialized->Initialized->Post-initialized->Available->Available->Available->Available

baseexample{DEV-1.0} [Tom´s Mod] (bin) Unloaded->Constructed->Pre-initialized->Initialized->Post-initialized->Available->Available->Available->Available

Loaded coremods (and transformers):

Launched Version: 1.8

LWJGL: 2.9.1

OpenGL: GeForce GTX 560/PCIe/SSE2 GL version 4.5.0 NVIDIA 347.88, NVIDIA Corporation

GL Caps: Using GL 1.3 multitexturing.

Using GL 1.3 texture combiners.

Using framebuffer objects because OpenGL 3.0 is supported and separate blending is supported.

Shaders are available because OpenGL 2.1 is supported.

VBOs are available because OpenGL 1.5 is supported.

 

Using VBOs: No

Is Modded: Definitely; Client brand changed to 'fml,forge'

Type: Client (map_client.txt)

Resource Packs: []

Current Language: English (US)

Profiler Position: N/A (disabled)

[20:00:00] [Client thread/INFO] [sTDOUT]: [net.minecraft.init.Bootstrap:printToSYSOUT:660]: #@!@# Game crashed! Crash report saved to: #@!@# D:\ForgeModding\Mods\BaseExample\.\crash-reports\crash-2015-04-22_20.00.00-client.txt

AL lib: (EE) alc_cleanup: 1 device not closed

 

 

(happens with all items)

From the Creative Menu the item works as intendet.

 

Mod Class:

 

package baseexample;

 

import net.minecraft.client.Minecraft;

import net.minecraft.init.Items;

import net.minecraft.item.ItemStack;

import net.minecraftforge.fml.common.FMLCommonHandler;

import net.minecraftforge.fml.common.Mod;

import net.minecraftforge.fml.common.Mod.EventHandler;

import net.minecraftforge.fml.common.event.FMLInitializationEvent;

import net.minecraftforge.fml.common.event.FMLPreInitializationEvent;

import net.minecraftforge.fml.relauncher.Side;

import baseexample.blocks.BaseBlock;

import baseexample.items.BaseArmor;

import baseexample.items.BaseBow;

import baseexample.items.BaseSword;

import baseexample.items.GameModeChanger;

import baseexample.items.GoldenArmor;

import baselib.create.DataCreator;

import baselib.lib.register.RegisterAll;

 

@Mod(modid = Reference.MODID, version = Reference.VERSION, dependencies = "after:baselib")

public class BaseExample implements IData {

private RegisterAll regi = new RegisterAll(Reference.MODID);

 

@EventHandler

public void preInit(FMLPreInitializationEvent ev) {

regi.preinitBlocks(new BaseBlock());

regi.preinitItem(new BaseSword(), new BaseBow(), new GameModeChanger(),

new BaseArmor(0), new BaseArmor(1), new BaseArmor(2),

new BaseArmor(3), new GoldenArmor());

}

 

@EventHandler

public void init(FMLInitializationEvent event) {

regi.initRender(Minecraft.getMinecraft().getRenderItem());

 

if (event.getSide() == Side.CLIENT) {

regi.registerRender();

}

 

regi.registerRecipe(new ItemStack(BaseExample.GOLDARM), "AA", "AA",

"B ", 'A', new ItemStack(Items.gold_ingot), 'B', new ItemStack(

Items.stick));

 

regi.registerRecipe(new ItemStack(BaseExample.BASESWORD), "A", "A",

"B", 'A', new ItemStack(Items.gold_nugget), 'B', new ItemStack(

Items.stick));

 

// Development

regi.creatAssetFolder(true, true);

regi.createData();

}

 

}

 

 

 

regi is a Class i wrote to register the blocks and items. registerRecipe() just calls GameRegistry.addRecipe.

The static item Objects are in IData:

 

IData:

 

 

package baseexample;

 

import baseexample.blocks.BaseBlock;

import baseexample.items.BaseArmor;

import baseexample.items.BaseBow;

import baseexample.items.BaseSword;

import baseexample.items.GameModeChanger;

import baseexample.items.GoldenArmor;

 

public interface IData

{

public static final BaseSword BASESWORD = new BaseSword();

public static final BaseBow BASEBOW = new BaseBow();

public static final GameModeChanger GAMECHANGER = new GameModeChanger();

public static final BaseArmor BASEARMORHELMET = new BaseArmor(0);

public static final BaseArmor BASEARMORCHEST = new BaseArmor(1);

public static final BaseArmor BASEARMORLEGG = new BaseArmor(2);

public static final BaseArmor BASEARMORBOOT = new BaseArmor(3);

public static final GoldenArmor GOLDARM = new GoldenArmor();

public static final BaseBlock BASEBLOCK = new BaseBlock();

}

 

 

BaseSword.java:

 

 

package baseexample.items;

 

import net.minecraft.creativetab.CreativeTabs;

import net.minecraft.item.ItemSword;

import net.minecraftforge.common.util.EnumHelper;

import net.minecraftforge.fml.common.registry.GameRegistry;

import baseexample.Reference;

import baselib.lib.abst.INamable;

 

public class BaseSword extends ItemSword implements INamable

{

 

public static final ToolMaterial BASEARIUMTOOL = EnumHelper.addToolMaterial("BASEARIUMTOOL", 1, 900, 2, 16, 30);

public static final String NAME = "basesword";

 

public BaseSword()

{

super(BASEARIUMTOOL);

setCreativeTab(CreativeTabs.tabCombat);

}

 

public String getName()

{

return NAME;

}

 

public String getLangName() {

return "Super Sword";

}

 

 

 

 

 

 

 

}

 

 

 

Greetings,

  some dude on the internet

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • My modded minecraft world don't go past 100% on the loading screen. My backup still work, but i've made a lot of progress from the point i was that save. i have already checked online and did some suggestions i found, but nothing worked. Here is my latest log + i don´t have crash reports: https://github.com/GmsantosPT/Minecraft-mod-problems/tree/main   Pls Help, Santos
    • Please share a link to your crash report, as explained in the FAQ
    • I have a block already registered in my mod, which I have used in some worlds. The problem arises when in code, I add a property called CURRENT_AGE, when running Minecraft it freezes. In the console it doesn't appear any excpetion except that it stays in this phase: [Render thread/DEBUG] [ne.mi.co.ca.CapabilityManager/CAPABILITIES]: Attempting to automatically register: Lnet/minecraftforge/items/IItemHandler; Does anyone have an idea what it could be? I show the block and its registration public class SoulLichenBlock extends MultifaceBlock implements SimpleWaterloggedBlock, EntityBlock { public static final BooleanProperty WATERLOGGED = BlockStateProperties.WATERLOGGED; public static final IntegerProperty SKILL_LEVEL = IntegerProperty.create("soullichen_level", 0, 30); public static final DirectionProperty FACE = DirectionProperty.create("soullichen_face"); public static final DirectionProperty DIRECTION = DirectionProperty.create("soullichen_direction"); public static final IntegerProperty CURRENT_AGE = BlockStateProperties.AGE_25; private final MultifaceSpreader spreader = new MultifaceSpreader(this); private final MultifaceSpreader.DefaultSpreaderConfig config = new MultifaceSpreader.DefaultSpreaderConfig(this); private LivingEntity owner; //private static final Integer MAX_AGE = 25; public SoulLichenBlock(Properties properties) { super(properties); this.registerDefaultState(this .defaultBlockState() .setValue(WATERLOGGED, Boolean.FALSE) .setValue(SKILL_LEVEL, 0) .setValue(FACE, Direction.DOWN) .setValue(DIRECTION, Direction.DOWN) .trySetValue(CURRENT_AGE, 0) ); } public static ToIntFunction<BlockState> emission(int p_181223_) { return (p_181221_) -> MultifaceBlock.hasAnyFace(p_181221_) ? p_181223_ : 0; } public static boolean hasFace(BlockState p_153901_, @NotNull Direction p_153902_) { BooleanProperty booleanproperty = getFaceProperty(p_153902_); return p_153901_.hasProperty(booleanproperty) && p_153901_.getValue(booleanproperty); } protected void createBlockStateDefinition(StateDefinition.@NotNull Builder<Block, BlockState> stateDefinition) { stateDefinition.add(WATERLOGGED).add(SKILL_LEVEL).add(FACE).add(DIRECTION).add(CURRENT_AGE); super.createBlockStateDefinition(stateDefinition); } public @NotNull BlockState updateShape(BlockState p_153302_, @NotNull Direction p_153303_, @NotNull BlockState p_153304_, @NotNull LevelAccessor p_153305_, @NotNull BlockPos p_153306_, @NotNull BlockPos p_153307_) { if (p_153302_.getValue(WATERLOGGED)) { p_153305_.scheduleTick(p_153306_, Fluids.WATER, Fluids.WATER.getTickDelay(p_153305_)); } return super.updateShape(p_153302_, p_153303_, p_153304_, p_153305_, p_153306_, p_153307_); } @SuppressWarnings("deprecation") public @NotNull FluidState getFluidState(BlockState fluidState) { return fluidState.getValue(WATERLOGGED) ? Fluids.WATER.getSource(false) : super.getFluidState(fluidState); } public boolean propagatesSkylightDown(BlockState p_181225_, @NotNull BlockGetter blockGetter, @NotNull BlockPos blockPos) { return p_181225_.getFluidState().isEmpty(); } public @NotNull MultifaceSpreader getSpreader() { return this.spreader; } public Optional<MultifaceSpreader.SpreadPos> spreadFromRandomFaceTowardRandomDirection( BlockState p_221620_, LevelAccessor p_221621_, BlockPos p_221622_, RandomSource p_221623_, int skillPoints, int age) { return Direction.allShuffled(p_221623_).stream().filter((p_221680_) -> { return this.config.canSpreadFrom(p_221620_, p_221680_); }).map((p_221629_) -> { return this.spreadFromFaceTowardRandomDirection(p_221620_, p_221621_, p_221622_, p_221629_, p_221623_, false, skillPoints, age); }).filter(Optional::isPresent).findFirst().orElse(Optional.empty()); } public Optional<MultifaceSpreader.SpreadPos> spreadFromFaceTowardRandomDirection( BlockState blockState, LevelAccessor levelAccessor, BlockPos blockPos, Direction face, RandomSource randomSource, boolean aBoolean, int skillPoints, int age) { return Direction.allShuffled(randomSource).stream().map((direction) -> spreadFromFaceTowardDirection(blockState, levelAccessor, blockPos, face, direction, aBoolean, skillPoints, age)) .filter(Optional::isPresent) .findFirst() .orElse(Optional.empty()); } public Optional<MultifaceSpreader.SpreadPos> spreadFromFaceTowardDirection( BlockState blockState, LevelAccessor levelAccessor, BlockPos blockPos, Direction face, Direction direction, boolean aBoolean, int skillPoints, int age) { //DevilRpg.LOGGER.debug("BEGIN ==================================== spreadFromFaceTowardDirection skillPoints {}", skillPoints); return skillPoints < 0 ? Optional.empty() : getSpreadFromFaceTowardDirection(blockState, levelAccessor, blockPos, face, direction, this::canSpreadInto) .flatMap((spreadPos) -> { //DevilRpg.LOGGER.debug("END ================================ spreadFromFaceTowardDirection spreadPos {}", spreadPos); return this.spreadToFace(levelAccessor, spreadPos, aBoolean, skillPoints, direction, age); }); } public boolean canSpreadInto(BlockGetter p_221685_, BlockPos p_221686_, MultifaceSpreader.SpreadPos p_221687_) { BlockState blockstate = p_221685_.getBlockState(p_221687_.pos()); return this.stateCanBeReplaced(p_221685_, p_221686_, p_221687_.pos(), p_221687_.face(), blockstate) && isValidStateForPlacement(p_221685_, blockstate, p_221687_.pos(), p_221687_.face()); } protected boolean stateCanBeReplaced(BlockGetter p_221688_, BlockPos p_221689_, BlockPos p_221690_, Direction p_221691_, BlockState p_221692_) { return p_221692_.isAir() || p_221692_.is(this) || p_221692_.is(Blocks.WATER) && p_221692_.getFluidState().isSource(); } public Optional<MultifaceSpreader.SpreadPos> getSpreadFromFaceTowardDirection(BlockState blockState, BlockGetter blockGetter, BlockPos blockPos, Direction face, Direction direction, MultifaceSpreader.SpreadPredicate spreadPredicate) { //DevilRpg.LOGGER.debug("--- getSpreadFromFaceTowardDirection direction.getAxis() == face.getAxis(): {}", direction.getAxis() == face.getAxis()); ArrayList<Direction> directions = new ArrayList<>(); directions.add(direction); if (direction.getAxis() == face.getAxis()) { if (direction.getAxis().isHorizontal()) { directions = Arrays.stream(Direction.values()).filter(dir -> dir.getAxis().isVertical()).collect(Collectors.toCollection(ArrayList::new)); } if (direction.getAxis().isVertical()) { directions = Arrays.stream(Direction.values()).filter(dir -> dir.getAxis().isHorizontal()).collect(Collectors.toCollection(ArrayList::new)); } } for (Direction directionElement : directions) { /*DevilRpg.LOGGER.debug("--->> getSpreadFromFaceTowardDirection config.isOtherBlockValidAsSource(blockState) {} || " + "hasFace(blockState, face) {} && " + "!hasFace(blockState, direction) {}", config.isOtherBlockValidAsSource(blockState), hasFace(blockState, face), !hasFace(blockState, directionElement));*/ if (config.isOtherBlockValidAsSource(blockState) || hasFace(blockState, face) && !hasFace(blockState, directionElement)) { for (MultifaceSpreader.SpreadType multifacespreader$spreadtype : config.getSpreadTypes()) { MultifaceSpreader.SpreadPos multifacespreader$spreadpos = multifacespreader$spreadtype.getSpreadPos(blockPos, directionElement, face); //DevilRpg.LOGGER.debug("--- test SpreadPos: {} direction {} face {} ", multifacespreader$spreadpos, directionElement, face); if (spreadPredicate.test(blockGetter, blockPos, multifacespreader$spreadpos)) { //DevilRpg.LOGGER.debug("--- spreadPredicate success:"); return Optional.of(multifacespreader$spreadpos); } } } } return Optional.empty(); } public boolean isValidStateForPlacement(@NotNull BlockGetter blockGetter, @NotNull BlockState blockState, @NotNull BlockPos blockPos, @NotNull Direction face) { //DevilRpg.LOGGER.debug("------ isValidStateForPlacement 1st condition: {} && ({} || {})", this.isFaceSupported(face), !blockState.is(this), !hasFace(blockState, face)); if (this.isFaceSupported(face) && (!blockState.is(this) || !hasFace(blockState, face))) { BlockPos blockpos = blockPos.relative(face); //DevilRpg.LOGGER.debug("------ isValidStateForPlacement 2nd condition: canAttachTo {} ", secondCondition); return canAttachTo(blockGetter, face, blockpos, blockGetter.getBlockState(blockpos)); } else { return false; } } @Nullable public BlockState getStateForPlacement(@NotNull BlockState blockState, @NotNull BlockGetter blockGetter, @NotNull BlockPos blockPos, @NotNull Direction face, int skillPoints, Direction direction, int age) { //DevilRpg.LOGGER.debug("--- getStateForPlacement"); boolean isNotValidStateForPlacement = !this.isValidStateForPlacement(blockGetter, blockState, blockPos, face); //DevilRpg.LOGGER.debug("------- isNotValidStateForPlacement: {}", isNotValidStateForPlacement); if (isNotValidStateForPlacement) { return null; } else { BlockState blockstate; if (blockState.is(this)) { blockstate = blockState; } else if (this.isWaterloggable() && blockState.getFluidState().isSourceOfType(Fluids.WATER)) { blockstate = this.defaultBlockState().setValue(BlockStateProperties.WATERLOGGED, Boolean.TRUE); } else { blockstate = this.defaultBlockState(); } //DevilRpg.LOGGER.debug("------- getStateForPlacement -> blockStateResult "); return blockstate .setValue(getFaceProperty(face), Boolean.TRUE) .setValue(SKILL_LEVEL, skillPoints).setValue(FACE, face) .setValue(DIRECTION, direction) .setValue(CURRENT_AGE,age) ; } } public Optional<MultifaceSpreader.SpreadPos> spreadToFace(LevelAccessor levelAccessor, MultifaceSpreader.SpreadPos spreadPos, boolean p_221596_, int skillPoints, Direction direction, int age) { BlockState blockstate = levelAccessor.getBlockState(spreadPos.pos()); //DevilRpg.LOGGER.debug("---> spreadToFace blockstate{} direction: {}", blockstate, direction); return this.placeBlock(levelAccessor, spreadPos, blockstate, p_221596_, skillPoints, direction, age) ? Optional.of(spreadPos) : Optional.empty(); } public boolean placeBlock(LevelAccessor p_221702_, MultifaceSpreader.SpreadPos p_221703_, BlockState p_221704_, boolean p_221705_, int skillPoints, Direction direction, int age) { //DevilRpg.LOGGER.debug("---> placeBlock {} direction {} ", p_221703_, direction); BlockState blockstate = this.getStateForPlacement(p_221704_, p_221702_, p_221703_.pos(), p_221703_.face(), skillPoints, direction, age); if (blockstate != null) { if (p_221705_) { p_221702_.getChunk(p_221703_.pos()).markPosForPostprocessing(p_221703_.pos()); } //DevilRpg.LOGGER.debug("------> setBlock"); return p_221702_.setBlock(p_221703_.pos(), blockstate, 2); } else { return false; } } public long spreadFromFaceTowardAllDirections( BlockState blockState, LevelAccessor levelAccessor, BlockPos blockPos, Direction face, boolean aBoolean, int skillPoints, int age) { return Direction.stream().map((p_221656_) -> spreadFromFaceTowardDirection(blockState, levelAccessor, blockPos, face, p_221656_, aBoolean, skillPoints, age)) .filter(Optional::isPresent).count(); } private boolean isWaterloggable() { return this.stateDefinition.getProperties().contains(BlockStateProperties.WATERLOGGED); } @Override public void setPlacedBy(@NotNull Level level, @NotNull BlockPos blockPos, @NotNull BlockState blockState, @Nullable LivingEntity livingEntity, @NotNull ItemStack itemStack) { super.setPlacedBy(level, blockPos, blockState, livingEntity, itemStack); this.setOwner(livingEntity); } public LivingEntity getOwner() { return this.owner; } private void setOwner(LivingEntity livingEntity) { this.owner = livingEntity; } @Deprecated @Override public void entityInside(@NotNull BlockState blockState, @NotNull Level level, @NotNull BlockPos blockPos, @NotNull Entity entity) { if (entity instanceof LivingEntity /*&& entity.getType() != EntityType.BEE*/ && entity.getType() != ModEntities.LICHEN_SEEDBALL.get()) { entity.makeStuckInBlock(blockState, new Vec3(0.8D, 0.75D, 0.8D)); if (!level.isClientSide /*&& (entity.xOld != entity.getX() || entity.zOld != entity.getZ())*/) { // double d0 = Math.abs(entity.getX() - entity.xOld); // double d1 = Math.abs(entity.getZ() - entity.zOld); // if (d0 >= (double) 0.003F || d1 >= (double) 0.003F) { entity.hurt(level.damageSources().playerAttack((Player) owner), 1.0F); // Aplicar aceleración al movimiento double speedBoost = -0.4; // Ajusta este valor según lo rápido que quieras que sea el impulso double motionX = entity.getX() - entity.xOld; double motionZ = entity.getZ() - entity.zOld; double speed = Math.sqrt(motionX * motionX + motionZ * motionZ); //if (speed > 0.0) { entity.setDeltaMovement(entity.getDeltaMovement().multiply( (motionX / speed) * speedBoost, 0.0, (motionZ / speed) * speedBoost )); // } //} } } } @Nullable @Override public BlockEntity newBlockEntity(@NotNull BlockPos pos, @NotNull BlockState state) { return ModEntityBlocks.SOUL_LICHEN_ENTITY_BLOCK.get().create(pos, state); } @Nullable @Override public <T extends BlockEntity> BlockEntityTicker<T> getTicker(Level level, @NotNull BlockState blockState, @NotNull BlockEntityType<T> type) { return level.isClientSide ? null : (alevel, pos, aBlockstate, blockEntity) -> { if (blockEntity instanceof SoulLichenBlockEntity soulLichenBlockEntity && alevel.getGameTime() % 5 == 0) { soulLichenBlockEntity.tick(blockState, (ServerLevel) alevel, pos, alevel.getRandom()); //DevilRpg.LOGGER.info("-------->tick. this: {}", this.getClass().getSimpleName()); } }; } }   This is the registration:   public final class ModBlocks { public static final DeferredRegister<Block> BLOCKS = DeferredRegister.create(ForgeRegistries.BLOCKS, DevilRpg.MODID); ... public static final RegistryObject<SoulLichenBlock> SOUL_LICHEN_BLOCK = BLOCKS.register("soullichen", () -> new SoulLichenBlock( Block.Properties.copy(Blocks.GLOW_LICHEN).lightLevel(SoulLichenBlock.emission(7)).randomTicks() )); }  
    • If you are using AMD/ATI, check for driver updates on their website - do not update via system
    • Hi, Create a new class that extends "Block" class and you need json for it in resources/assets/modid/blockstates directory and resources/assets/modid/models. You can generate json for it using a tool like misodes model generator. Here, atleast, are blocks explained at forge docs.  Don't forge to look at vanilla code, like Magma Block is a good reference if you're trying a "green fire block".  Modid should be replaced with your actual forge mod namespace!
  • Topics

  • Who's Online (See full list)

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.