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



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • https://mclo.gs/iVJZfGm https://privatebin.net/?442243857e9dcaca#5MhV8JAuhNJnN587jbG2pcVQi8VnvgAVafmpAd6Gnv91
    • So im making a mod for minecraft and i want to add custom fishing rods... aka fishing rods with different bait, depending on the bait you can have a higher chance of getting other fish. I want to make basically custom fishing rods with at least one custom loot table for each (so that i can choose which fish have a higher chance of being caught in a simpler way with said loot table) Problem is i dont know even where to start with doing this, like at all. Im very beginner with modding minecraft, any help (links to any source which could help me with this is also very helpful) would be great. 1.20 forge(of course)
    • Hi, my name is Gatis. Mostly all I do is play minecraft on Hypixel server. I play Skyblock where almost every player has installed QOL mods. They are nice and work nice but recently the grind I'm on requires not wasting time on boosts and if I'm watching something I usually miss it. Let me explain better. So there is "Mining speed boost" when it's ready message appears in chat. Mod I've been using allows to copy chat message, paste it in mod and next time same message appears it flashes big notification message on screen that speed boost is ready. The thing is somehow I still miss the notification. SO, I want to create mod that can detect that message and make more noticable notification (ex. bigger) or even stop me from moving for 10 sec if I don't use it instantly. I have no knowledge about java I have prepared intellij with forge on 1.8.9 I'm just left with this:                 package com.example.examplemod;                  import net.minecraft.init.Blocks;                import net.minecraftforge.fml.common.Mod;                import net.minecraftforge.fml.common.Mod.EventHandler;                import net.minecraftforge.fml.common.event.FMLInitializationEvent;                 @Mod(modid = ExampleMod.MODID, version = ExampleMod.VERSION)               public class GatisMOD              {                           public static final String MODID = "GatisMOD"; \                           public static final String VERSION = "1.0";                            @EventHandler                          public void init(FMLInitializationEvent event)                          {                                      // some example code                                      System.out.println("DIRT BLOCK >> "+Blocks.dirt.getUnlocalizedName());                          } }     I've watched many video, mostly they show how to setup everything but how to create, prepare file and later (export I guess) export to import in mods folder to use they don't I'd appreciate any help, maybe someone would explain some things to me. In future I have plans to make other feature but I guess not for now.
    • I don't think embeddium and rubidium can be used together. Try removing one of them.
    • I have been attempting to troubleshoot my personal modpack created on Curseforge for 1.18.2 Forge but I keep getting the Exit Code: 1 crash upon launching the game. When I open the debug.log I find the error for "Duplicate mods found" which simply isn't the case as there isn't a single mod with the same name. Most files are for the correct version as far as I can tell so I think there may be mods that are conflicting and the game is confusing them as "Duplicates". (Or I simply didn't check the versions correctly. Debug.log file paste: https://paste.ee/p/pQwZo#s=0 I don't normally frequent forums and don't normally ask for help online but guidance would be greatly appreciated. I can provide any other info needed  
  • Topics

×
×
  • Create New...

Important Information

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