Jump to content

[1.14.2] Registering EntityType throws casting exception


Big_Bad_E

Recommended Posts

I am trying to port an old 1.7.10 mod, and realizing how out of date it is, I decided a rewrite would be much better.

I am trying to make an entity, for now it has a few simple NBT functions, and a simple method, but nothing else.

Whenever I start MC, the game crashes during startup.

 

Registry:

@ObjectHolder("battlepets")
public class EntityRegistry {

    public static EntityType<AnimalEntity> PETENTITY;

    @SubscribeEvent
    public static void onEntityRegister(RegistryEvent.Register<EntityType<?>> event) {
        PETENTITY = (EntityType<AnimalEntity>) EntityType.Builder.create(new PetEntityFactory(), EntityClassification.CREATURE).build("pet").setRegistryName("battlepets", "pet");
        event.getRegistry().register(PETENTITY);
    }
}

Factory:

public class PetEntityFactory implements EntityType.IFactory<Entity> {
    @Override
    public Entity create(EntityType type, World world) {
        return new PetEntity(world, PetType.DOG, null);
    }
}

Entity (probably not needed):

Spoiler

public class PetEntity extends AnimalEntity {
    private int level;
    private int skillPoints;
    private boolean sitting;
    private PetType type;
    private UUID ownerUUID;

    public PetEntity(World worldIn, PetType type, UUID ownerUUID) {
        super(EntityRegistry.PETENTITY, worldIn);
        this.type = type;
        level = 0;
        sitting = false;
        skillPoints = 1;
        this.ownerUUID = ownerUUID;
    }

    //TODO add breedable pets
    @Nullable
    @Override
    public AgeableEntity createChild(AgeableEntity ageable) {
        return null;
    }

    public void setOwnerUUID(UUID uuid) {
        this.ownerUUID = uuid;
    }

    public void setPetType(PetType type) {
        this.type = type;
    }

    public void setSitting(boolean sitting) {
        this.sitting = sitting;
    }

    public void setCustomName(String name) {
        setCustomName(new StringTextComponent(name));
    }

    public void setLevel(int level) {
        this.level = level;
    }

    public void setFreeSkillPoints(int points) {
        this.skillPoints = points;
    }

    public int getLevel() {
        return level;
    }

    public int getFreeSkillPoints() {
        return skillPoints;
    }

    public void levelUp() {
        if (getLevel() >= Level.MAX_LEVEL) {
            return;
        }

        setLevel(getLevel() + 1);
        setFreeSkillPoints(getFreeSkillPoints() + 1);
    }

    @Override
    public void writeAdditional(CompoundNBT compound) {
        compound.putInt("level", level);
        compound.putInt("skillPoints", skillPoints);
        compound.putInt("petType", type.ordinal());

        compound.putBoolean("sitting", sitting);

        compound.putUniqueId("owner", ownerUUID);
    }

    @Override
    public void readAdditional(CompoundNBT compound) {
        level = compound.getInt("level");
        skillPoints = compound.getInt("skillPoints");
        type = PetType.values()[compound.getInt("petType")];

        sitting = compound.getBoolean("sitting");

        ownerUUID = compound.getUniqueId("owner");
    }
}

 

Error:

Spoiler

[18:03:26.480] [Client thread/FATAL] [minecraft/Minecraft]: Reported exception thrown!
net.minecraft.crash.ReportedException: Rendering overlay
    at net.minecraft.client.renderer.GameRenderer.updateCameraAndRender(GameRenderer.java:563) ~[forge-1.14.2-26.0.62_mapped_snapshot_20190621-1.14.2-recomp.jar:?] {pl:accesstransformer:B,pl:runtimedistcleaner:A}
    at net.minecraft.client.Minecraft.runGameLoop(Minecraft.java:920) ~[forge-1.14.2-26.0.62_mapped_snapshot_20190621-1.14.2-recomp.jar:?] {pl:accesstransformer:B,pl:runtimedistcleaner:A}
    at net.minecraft.client.Minecraft.run(Minecraft.java:384) ~[forge-1.14.2-26.0.62_mapped_snapshot_20190621-1.14.2-recomp.jar:?] {pl:accesstransformer:B,pl:runtimedistcleaner:A}
    at net.minecraft.client.main.Main.main(Main.java:127) ~[forge-1.14.2-26.0.62_mapped_snapshot_20190621-1.14.2-recomp.jar:?] {pl:runtimedistcleaner:A}
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.8.0_201] {}
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[?:1.8.0_201] {}
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:1.8.0_201] {}
    at java.lang.reflect.Method.invoke(Method.java:498) ~[?:1.8.0_201] {}
    at net.minecraftforge.userdev.FMLUserdevClientLaunchProvider.lambda$launchService$0(FMLUserdevClientLaunchProvider.java:55) ~[forge-1.14.2-26.0.62_mapped_snapshot_20190621-1.14.2-recomp.jar:?] {}
    at cpw.mods.modlauncher.LaunchServiceHandlerDecorator.launch(LaunchServiceHandlerDecorator.java:37) [modlauncher-2.1.4.jar:?] {}
    at cpw.mods.modlauncher.LaunchServiceHandler.launch(LaunchServiceHandler.java:50) [modlauncher-2.1.4.jar:?] {}
    at cpw.mods.modlauncher.LaunchServiceHandler.launch(LaunchServiceHandler.java:68) [modlauncher-2.1.4.jar:?] {}
    at cpw.mods.modlauncher.Launcher.run(Launcher.java:77) [modlauncher-2.1.4.jar:?] {}
    at cpw.mods.modlauncher.Launcher.main(Launcher.java:62) [modlauncher-2.1.4.jar:?] {}
    at net.minecraftforge.userdev.LaunchTesting.main(LaunchTesting.java:101) [forge-1.14.2-26.0.62_mapped_snapshot_20190621-1.14.2-recomp.jar:?] {}
Caused by: java.lang.ClassCastException: net.minecraft.entity.EntityType cannot be cast to net.minecraft.block.Block
    at net.minecraft.client.renderer.model.ModelBakery.<init>(ModelBakery.java:116) ~[?:?] {pl:accesstransformer:B,pl:runtimedistcleaner:A}
    at net.minecraftforge.client.model.ModelLoader.<init>(ModelLoader.java:141) ~[?:?] {}
    at net.minecraft.client.renderer.model.ModelManager.prepare(ModelManager.java:48) ~[?:?] {pl:runtimedistcleaner:A}
    at net.minecraft.client.renderer.model.ModelManager.prepare(ModelManager.java:13) ~[?:?] {pl:runtimedistcleaner:A}
    at net.minecraft.client.resources.ReloadListener.lambda$reload$0(ReloadListener.java:15) ~[?:?] {pl:runtimedistcleaner:A}
    at java.util.concurrent.CompletableFuture$AsyncSupply.run(CompletableFuture.java:1590) ~[?:1.8.0_201] {}
    at java.util.concurrent.CompletableFuture$AsyncSupply.exec(CompletableFuture.java:1582) ~[?:1.8.0_201] {}
    at java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:289) ~[?:1.8.0_201] {}
    at java.util.concurrent.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1056) ~[?:1.8.0_201] {}
    at java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1692) ~[?:1.8.0_201] {}
    at java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:157) ~[?:1.8.0_201] {}

 

Link to comment
Share on other sites

1 minute ago, Big_Bad_E said:

Caused by: java.lang.ClassCastException: net.minecraft.entity.EntityType cannot be cast to net.minecraft.block.Block

Somewhere you are casting it to a Block...Or using it as a Block.

Edited by Animefan8888

VANILLA MINECRAFT CLASSES ARE THE BEST RESOURCES WHEN MODDING

I will be posting 1.15.2 modding tutorials on this channel. If you want to be notified of it do the normal YouTube stuff like subscribing, ect.

Forge and vanilla BlockState generator.

Link to comment
Share on other sites

5 minutes ago, Animefan8888 said:

Somewhere you are casting it to a Block...Or using it as a Block.

It is being cast to a block by Forge, and it is in the block registry somehow?

Error line:

for(Block block : Registry.BLOCK) {
         block.getStateContainer().getValidStates().forEach((p_217837_1_) -> {
            this.func_217843_a(BlockModelShapes.getModelLocation(p_217837_1_));
         });
      }

(From ModelBakery.java)

 

I register an item in the mod too, but no blocks at all.

Edited by Big_Bad_E
Link to comment
Share on other sites

8 minutes ago, Big_Bad_E said:

I register an item in the mod too, but no blocks at all.

Post all of your code. Preferably as a git repo.

VANILLA MINECRAFT CLASSES ARE THE BEST RESOURCES WHEN MODDING

I will be posting 1.15.2 modding tutorials on this channel. If you want to be notified of it do the normal YouTube stuff like subscribing, ect.

Forge and vanilla BlockState generator.

Link to comment
Share on other sites

Yep, using EVENT_BUS.register() worked. Thanks!

 

Edit: It just didn't call the event.

What do I use? I tried @Mod.EventBusSubscriber but no luck.

 

Nevermind, I used @Mod.EventBusSubscriber(bus = Mod.EventBusSubscriber.Bus.MOD)

Edited by Big_Bad_E
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.

Announcements



×
×
  • Create New...

Important Information

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