Big_Bad_E Posted August 26, 2019 Share Posted August 26, 2019 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] {} Quote Link to comment Share on other sites More sharing options...
Animefan8888 Posted August 26, 2019 Share Posted August 26, 2019 (edited) 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, 2019 by Animefan8888 Quote 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 More sharing options...
Big_Bad_E Posted August 26, 2019 Author Share Posted August 26, 2019 (edited) 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, 2019 by Big_Bad_E Quote Link to comment Share on other sites More sharing options...
Animefan8888 Posted August 26, 2019 Share Posted August 26, 2019 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. Quote 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 More sharing options...
Big_Bad_E Posted August 27, 2019 Author Share Posted August 27, 2019 33 minutes ago, Animefan8888 said: Post all of your code. Preferably as a git repo. https://github.com/BigBadE/BattlePets Quote Link to comment Share on other sites More sharing options...
Big_Bad_E Posted August 27, 2019 Author Share Posted August 27, 2019 (edited) 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, 2019 by Big_Bad_E Quote Link to comment Share on other sites More sharing options...
Recommended Posts
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.