Posted October 6, 201510 yr Hi, me again. I do the following in my mod: @EventHandler public void postInit(FMLPostInitializationEvent event) { MinecraftForge.TERRAIN_GEN_BUS.register(new GenStructure()); logger.info("Registered WorldGen Events!"); } That works. Then I call in GenStructures(): public class GenStructure { @SubscribeEvent(priority=EventPriority.HIGHEST) public void onInitMapGenEvent(InitMapGenEvent event) { if(event.type.toString() == "VILLAGE") { event.newGen = new NoVillage(); MyClass.logger.info("Stopped generation of village"); } } } That works too so far, but now in NoVillage: public class NoVillage extends MapGenVillage { @Override public boolean canSpawnStructureAtCoords(int var1, int var2) { MyClass.logger.info("test"); return false; } } And that does not work. The line "test" never appears in the log and the village is generated even though I don't want it. Where is my error?
October 6, 201510 yr Author if(event.type.toString() == "VILLAGE") This will never be true. Just compare the enum value, not the String. As for Strings, you need to compare them using equals. Ehm, but it works, because this is in the logs: [21:58:52] [server thread/INFO] [MyMod]: Stopped generation of village
October 6, 201510 yr Author Okay, I solved it. After changing @SubscribeEvent(priority=EventPriority.HIGHEST) to @SubscribeEvent(priority=EventPriority.LOWEST) everything works now. I don't know exactly why.
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.