Posted August 26, 20196 yr 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] {}
August 26, 20196 yr 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 August 26, 20196 yr 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.
August 26, 20196 yr Author 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 August 26, 20196 yr by Big_Bad_E
August 26, 20196 yr 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.
August 27, 20196 yr Author 33 minutes ago, Animefan8888 said: Post all of your code. Preferably as a git repo. https://github.com/BigBadE/BattlePets
August 27, 20196 yr Author 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 August 27, 20196 yr by Big_Bad_E
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.