Jump to content

Recommended Posts

Posted

Hello everyone, I'm new to modding and can't make my content load.

 

What happens is that  anything annotated with @SubscribeEvent doesn't react to events. I tried it with and without @EntityBusSubscriber on the class, tried making the methods static and moving them to other classes, but it doesn't help.

 

Here is the relevant code. (it's in Kotlin but it shouldn't be too hard to read)

@Mod(modid = SimpleFlora.MODID, name = SimpleFlora.NAME, version = SimpleFlora.VERSION, modLanguageAdapter = SimpleFlora.ADAPTER)
@Mod.EventBusSubscriber
object SimpleFlora {
    const val MODID = "simpleflora"
    const val NAME = "Simple Flora"
    const val VERSION = "0.1"

    const val ADAPTER = "net.shadowfacts.forgelin.KotlinAdapter"
    const val SERVER_PROXY = "azmalent.$MODID.proxy.ServerProxy"
    const val CLIENT_PROXY = "azmalent.$MODID.proxy.ClientProxy"

    @Mod.Instance
    lateinit var instance: SimpleFlora

    @SidedProxy(serverSide = SERVER_PROXY, clientSide = CLIENT_PROXY)
    lateinit var proxy: AbstractProxy

    lateinit var config: Configuration
    lateinit var logger: Logger

    @Mod.EventHandler
    fun preInit(event: FMLPreInitializationEvent) {
        logger = event.modLog

        val directory = event.modConfigurationDirectory
        config = Configuration(File(directory.path, "$MODID.cfg"))
        ModConfig.init()

        proxy.preInit(event)
    }

    @Mod.EventHandler
    fun init(event: FMLInitializationEvent) {
        proxy.init(event)
    }

    @Mod.EventHandler
    fun postInit(event: FMLPostInitializationEvent) {
        proxy.postInit(event)
    }

    @SubscribeEvent
    fun registerBlocks(event: RegistryEvent.Register<Block>) {
        SimpleFlora.logger.info("Registering blocks")
        ModBlocks.register(event.registry)
    }

    @SubscribeEvent
    fun registerItems(event: RegistryEvent.Register<Item>) {
        SimpleFlora.logger.info("Registering itemBlocks")
        ModBlocks.registerItemBlocks(event.registry)
    }
}

 

Sorry if I have a silly mistake somewhere, I spent like 4 hours and couldn't find where the problem is. Everything looks identical to the tutorials I used.

Can anybody help me out? Thanks in advance :)

Posted

Registering the class as an event subscriber requires that the event handler methods be static. I don't know how Kotlin defines that, but that's what the problem likely is.

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

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.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • So am trying to make a custom 1.19.2 modpack and everything works until I add Oculus. I have tried Oculus+Embedium and Oculus+Rubdium and by themselves they work but as soon as I add anything it crashes no matter what it is. The modpack works fine with just Embedium and Rubdium. Can you help me to see if this is something i can fix or do i just have to deal with not having shaders. Here is the crash log. Thank you for your time. https://paste.ee/p/WXfNZ24K
    • What do I do now when it says "1 error"?
    • Hello everyone new here how are you all?
    • I haven't tested it but under https://minecraft.wiki/w/Items_model_definition it says now:   So I guess the resource location must have changed with 1.24.4, which means you need to move your models/item/ to the new source. But as I said I haven't tested this so it also may be that this wont work. Nevertheless give it a try      EDIT (important) So now I tested it and found out how it works   Let the model files (e.g. the .json from blockbench) within "assets/<your_mod_id>/models/item" In addition to that do the following: Every model you added will need a new file under "assets/<your_mod_id>/items" That file is also a JSON and looks like this: { "model": { "type": "minecraft:model", "model": "your_mod_id:item/custom_item" } } - "type" can be minecraft:model, minecraft:composite, minecraft:condition, minecraft:select, minecraft:range_dispatch, minecraft:empty, minecraft:bundle/selected_item or minecraft:special. (In most cases you would need minecraft:model) - "model" is the path to your actual model for this item. For example the value above would point to "assets/your_mod_id/models/item/custom_item"
  • Topics

×
×
  • Create New...

Important Information

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