Jump to content

Recommended Posts

Posted

Hi everyone, I'm a bit confused on how Forge handles the spawn of custom entities. I have created a test project to show what confuses me (GitHub repository).

 

In my test mod I have created an entity called TestEntity that only has one extra boolean parameter called shorty that controls if the entity is rendered as block or as a slab (TestEntityRenderer checks this flag and renders one of two models accordingly).  Here is the code for the Entity class, readAdditional is overridden to read shorty from the NBT.

package com.github.neutrinokillerino.entitytest.entity;

import net.minecraft.entity.Entity;
import net.minecraft.entity.EntityType;
import net.minecraft.nbt.CompoundNBT;
import net.minecraft.network.IPacket;
import net.minecraft.world.World;
import net.minecraftforge.fml.network.NetworkHooks;

public class TestEntity extends Entity {
	
	public boolean shorty = false;
	
	public TestEntity(EntityType<?> entityTypeIn, World worldIn) {
		super(entityTypeIn, worldIn);
		// TODO Auto-generated constructor stub
	}

	@Override
	protected void registerData() {
		// TODO Auto-generated method stub
	}

	@Override
	protected void readAdditional(CompoundNBT compound) {
		// TODO Auto-generated method stub
		this.shorty = compound.getBoolean("shorty");
	}

	@Override
	protected void writeAdditional(CompoundNBT compound) {
		// TODO Auto-generated method stub
		
	}

	@Override
	public IPacket<?> createSpawnPacket() {
		// TODO Auto-generated method stub
		return NetworkHooks.getEntitySpawningPacket(this);
	}

}

 

Here is what confuses me, when I spawn the entity using the summon command /summon entitytest:test_entity ~ ~ ~ {shorty:true} the following happens (inspected using breakpoints on eclipse):

  1.  Constructor is called.entityID = 4247
  2.  readAdditional is called. NBT contains information passed through command and shorty is set totrue. entityID = 4247
  3.  createSpawnPacket is called. shorty has valuetrue. entityID = 4247
  4. Constructor is called again. entityID = 4248
  5.  Renderer is called with an  entity with ID 4247,shorty is false.

 

Why is the constructor called twice and why is shorty set to false again?

 

Something weird also happens when I create an item that spawns the entity. The item is PlacerItem and it's class is:

package com.github.neutrinokillerino.entitytest.item;

import com.github.neutrinokillerino.entitytest.init.ModEntityTypes;

import net.minecraft.entity.SpawnReason;
import net.minecraft.item.Item;
import net.minecraft.item.ItemUseContext;
import net.minecraft.nbt.CompoundNBT;
import net.minecraft.util.ActionResultType;
import net.minecraft.util.Direction;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.World;

public class PlacerItem extends Item {

	public PlacerItem(Properties properties) {
		super(properties);
	}
	
	public ActionResultType onItemUse(ItemUseContext context) {
		BlockPos blockpos = context.getPos();
		Direction direction = context.getFace();
		BlockPos blockpos1 = blockpos.offset(direction);
		World world = context.getWorld();
		
		
		if (!world.isRemote()) {
			CompoundNBT compound = new CompoundNBT();
			compound.putBoolean("shorty", true);
			ModEntityTypes.TEST_ENTITY.get().spawn(world, compound, null, null, blockpos1, SpawnReason.SPAWN_EGG, false, false);
		}
		
		return ActionResultType.SUCCESS;
	}

}

 

When using the item, the following happens:

  1. Constructor is called. entityID = 4254
  2.  createSpawnPacket is called.entityID = 4254
  3. Constructor is called. entityID = 4255
  4. Renderer is called. entityID = 4254

In this case, readAdditional is not called and the constructor is  called two times.

 

I have also tried to create a bifunction as the constructor but then the calls  get very messy.

I'd be grateful if anyone could clarify how Forge calls everything and how the spawn packet is handled.

 

Thanks.

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

    • Oh I forgot to update the title. I figured out the issue and I'm rather embarrassed to say that it was a file path issue. The game already knew I was accessing the achievements so I wasn't suppose to include advancements in the file path. Minecraft file paths have always confused me a little bit... ResourceLocation advancementId = new ResourceLocation( TheDeadRise.MODID,"adventure/spawntrigger");
    • Can someone help my with this? My forge server won't open and I'm not that good with this stuff. It gave me this error message:   C:\Users\apbeu\Desktop\Forge server>java -Xmx4G -Xms1G -jar server.jar nogui 2024-12-11 18:21:01,054 main WARN Advanced terminal features are not available in this environment [18:21:01] [main/INFO] [cp.mo.mo.Launcher/MODLAUNCHER]: ModLauncher running: args [--gameDir, ., --launchTarget, fmlserver, --fml.forgeVersion, 36.2.34, --fml.mcpVersion, 20210115.111550, --fml.mcVersion, 1.16.5, --fml.forgeGroup, net.minecraftforge, nogui] [18:21:01] [main/INFO] [cp.mo.mo.Launcher/MODLAUNCHER]: ModLauncher 8.1.3+8.1.3+main-8.1.x.c94d18ec starting: java version 21.0.4 by Oracle Corporation Exception in thread "main" java.lang.IllegalAccessError: class cpw.mods.modlauncher.SecureJarHandler (in unnamed module @0x402e37bc) cannot access class sun.security.util.ManifestEntryVerifier (in module java.base) because module java.base does not export sun.security.util to unnamed module @0x402e37bc         at cpw.mods.modlauncher.SecureJarHandler.lambda$static$1(SecureJarHandler.java:45)         at cpw.mods.modlauncher.api.LamdbaExceptionUtils.uncheck(LamdbaExceptionUtils.java:95)         at cpw.mods.modlauncher.SecureJarHandler.<clinit>(SecureJarHandler.java:45)         at cpw.mods.modlauncher.Launcher.lambda$new$6(Launcher.java:55)         at java.base/java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1708)         at cpw.mods.modlauncher.api.TypesafeMap.computeIfAbsent(TypesafeMap.java:52)         at cpw.mods.modlauncher.api.TypesafeMap.computeIfAbsent(TypesafeMap.java:47)         at cpw.mods.modlauncher.Environment.computePropertyIfAbsent(Environment.java:62)         at cpw.mods.modlauncher.Launcher.<init>(Launcher.java:55)         at cpw.mods.modlauncher.Launcher.main(Launcher.java:66)         at net.minecraftforge.server.ServerMain$Runner.runLauncher(ServerMain.java:63)         at net.minecraftforge.server.ServerMain$Runner.access$100(ServerMain.java:60)         at net.minecraftforge.server.ServerMain.main(ServerMain.java:57) C:\Users\apbeu\Desktop\Forge server>pause
    • Here is the url for the crash report if anyone can help me, please. https://mclo.gs/KGn5LWy  
    • Every single time I try and open my modpack it crashes before the game fully opens and I don't know what is wrong. I open the crash logs but I don't understand what any of it means. What do I do?
    • Hey, sorry I haven't said anything in a while. I was banned on here for sending you straight up crash logs and they banned me for spam... but I learned that these forums are for forge only and I was working with neoforge... but thank you for all the help.
  • Topics

×
×
  • Create New...

Important Information

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