Jump to content

Recommended Posts

Posted

Hi. I tried to add custom entity to my mod, but an something has happened. My game crashes after loading a world, and in logs file I can see:

  Quote

registerAttributes(Lnet/minecraftforge/event/entity/EntityAttributeCreationEvent;)V
java.lang.ExceptionInInitializerError

Expand  

Part of the code looks like this:

package com.kolan.thoriummod.Event;

import com.kolan.common.entity.Impostor;
import com.kolan.thoriummod.Entity.EntityInit;
import com.kolan.thoriummod.Thorium;
import net.minecraftforge.event.entity.EntityAttributeCreationEvent;
import net.minecraftforge.eventbus.api.SubscribeEvent;
import net.minecraftforge.fml.common.Mod;

@Mod.EventBusSubscriber(modid = Thorium.MOD_ID, bus = Mod.EventBusSubscriber.Bus.MOD)
public class CommonModEvents {

    @SubscribeEvent
    public static void registerAttributes(EntityAttributeCreationEvent event){
        event.put(EntityInit.IMPOSTOR.get(), Impostor.createAttributes().build());
    }
}

What can I do? Thanks in advance

Posted (edited)
  Reveal hidden contents

That's all I got

Edited by Kolan
Posted (edited)

Hi!

This means that 

  On 4/14/2022 at 9:04 AM, Luis_ST said:

thorium:Impostor

Expand  

Has a character inside it, that is not a-z 0-9 or /._-, in this case the big I in impostor. Registry names are always lowercase 

Edited by OutCraft
  • Like 1

Sorry if my Posts are weird sometimes, I just try to help and learn as much as I can :D

Also: PLEASE use SPOILERS for logs!

Posted

Ok, I changed it, but I have different error in my logs

  Reveal hidden contents

What has happened here?

Posted

Mod main class:

package com.kolan.thoriummod;

import com.kolan.thoriummod.Entity.ModEntities;
import com.kolan.thoriummod.block.ModBlocks;
import com.kolan.thoriummod.item.ModItems;
import com.mojang.logging.LogUtils;
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.eventbus.api.IEventBus;
import net.minecraftforge.fml.common.Mod;
import net.minecraftforge.fml.event.lifecycle.FMLClientSetupEvent;
import net.minecraftforge.fml.event.lifecycle.FMLCommonSetupEvent;
import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext;
import org.slf4j.Logger;


@Mod("thorium")
public class Thorium
{
    private static final Logger LOGGER = LogUtils.getLogger();
    public static final String MOD_ID = "thorium";

    public Thorium()
    {
        IEventBus eventBus = FMLJavaModLoadingContext.get().getModEventBus();

        ModEntities.register(eventBus);
        ModItems.register(eventBus);
        ModBlocks.register(eventBus);


        eventBus.addListener(this::setup);

        MinecraftForge.EVENT_BUS.register(this);
    }

    private void setup(final FMLCommonSetupEvent event) { }

    private void doClientStuff(final FMLClientSetupEvent event) { }
}

Entity registry:

package com.kolan.thoriummod.Entity;

import com.kolan.common.entity.impostor;
import com.kolan.thoriummod.Thorium;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.entity.EntityType;
import net.minecraft.world.entity.MobCategory;
import net.minecraftforge.registries.DeferredRegister;
import net.minecraftforge.registries.ForgeRegistries;
import net.minecraftforge.registries.RegistryObject;

public class EntityInit {

    private EntityInit(){

    }

    public static final DeferredRegister<EntityType<?>> ENTITIES = DeferredRegister.create(ForgeRegistries.ENTITIES, Thorium.MOD_ID);

    public static final RegistryObject<EntityType<impostor>> IMPOSTOR = ENTITIES.register("impostor",
            () -> EntityType.Builder.of(impostor::new, MobCategory.CREATURE).sized(0.5f,0.5f)
                    .build(new ResourceLocation(Thorium.MOD_ID, "impostor").toString()));
}

 

Posted

Also please show the class com.kolan.thoriummod.Event.CommonModEvents

  • Like 1

Sorry if my Posts are weird sometimes, I just try to help and learn as much as I can :D

Also: PLEASE use SPOILERS for logs!

Posted
package com.kolan.thoriummod.Event;

import com.kolan.common.entity.impostor;
import com.kolan.thoriummod.Entity.EntityInit;
import com.kolan.thoriummod.Thorium;
import net.minecraftforge.event.entity.EntityAttributeCreationEvent;
import net.minecraftforge.eventbus.api.SubscribeEvent;
import net.minecraftforge.fml.common.Mod;

@Mod.EventBusSubscriber(modid = Thorium.MOD_ID, bus = Mod.EventBusSubscriber.Bus.MOD)
public class CommonModEvents {

    @SubscribeEvent
    public static void registerAttributes(EntityAttributeCreationEvent event){
        event.put(EntityInit.IMPOSTOR.get(), impostor.createAttributes().build());
    }
}
Posted

ModEntities:

package com.kolan.thoriummod.Entity;

import com.kolan.common.entity.impostor;
import com.kolan.thoriummod.Thorium;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.entity.EntityType;
import net.minecraft.world.entity.MobCategory;
import net.minecraftforge.eventbus.api.IEventBus;
import net.minecraftforge.registries.DeferredRegister;
import net.minecraftforge.registries.ForgeRegistries;
import net.minecraftforge.registries.RegistryObject;

public class ModEntities {

    private ModEntities() {}

    public static final DeferredRegister<EntityType<?>> ENTITIES = DeferredRegister.create(ForgeRegistries.ENTITIES, Thorium.MOD_ID);

    public static final RegistryObject<EntityType<impostor>> IMPOSTOR = ENTITIES.register("impostor",
            () -> EntityType.Builder.of(impostor::new, MobCategory.MONSTER).sized(0.8f,0.8f)
                    .build(new ResourceLocation(Thorium.MOD_ID, "impostor").toString()));

    public static void register(IEventBus eventBus) {
    }
}

 

Posted
  On 4/14/2022 at 10:20 AM, Kolan said:
ModEntities.register(eventBus);
Expand  

Here you are calling 

  On 4/14/2022 at 10:27 AM, Kolan said:
public static void register(IEventBus eventBus) {
    }
Expand  

but you need to call the register method of 

  On 4/14/2022 at 10:27 AM, Kolan said:
public static final DeferredRegister<EntityType<?>> ENTITIES
Expand  
  • Like 1

Sorry if my Posts are weird sometimes, I just try to help and learn as much as I can :D

Also: PLEASE use SPOILERS for logs!

Posted

Also you are doing the same in 

  On 4/14/2022 at 10:20 AM, Kolan said:
ModItems.register(eventBus);
ModBlocks.register(eventBus);
Expand  

 

  • Like 1

Sorry if my Posts are weird sometimes, I just try to help and learn as much as I can :D

Also: PLEASE use SPOILERS for logs!

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



×
×
  • Create New...

Important Information

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