Jump to content

[1.7.2] TileEntityness


Pardeep

Recommended Posts

I have this mod that adds something very closely related to the furnace (in function terms, i.e. it smelts something and when that happens, it changes its texture and emits light) and in code terms (it's more or less furnace code tweaked). When I use it in single player, it works 100% fine.

 

However in a server, the following log appears.

Error log of server:

net.minecraft.util.ReportedException: Ticking block entity
at net.minecraft.server.MinecraftServer.updateTimeLightAndEntities(MinecraftServer.java:745) ~[MinecraftServer.class:?]
at net.minecraft.server.dedicated.DedicatedServer.updateTimeLightAndEntities(DedicatedServer.java:339) ~[DedicatedServer.class:?]
at net.minecraft.server.MinecraftServer.tick(MinecraftServer.java:650) ~[MinecraftServer.class:?]
at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:528) [MinecraftServer.class:?]
at net.minecraft.server.MinecraftServer$2.run(MinecraftServer.java:787) [MinecraftServer$2.class:?]
Caused by: java.lang.NullPointerException
at net.minecraft.world.chunk.storage.ExtendedBlockStorage.func_150818_a(ExtendedBlockStorage.java:100) ~[ExtendedBlockStorage.class:?]
at net.minecraft.world.chunk.Chunk.func_150807_a(Chunk.java:685) ~[Chunk.class:?]
at net.minecraft.world.World.setBlock(World.java:549) ~[World.class:?]
at net.minecraft.world.World.setBlock(World.java:697) ~[World.class:?]
at freshpower.blocks.steelifier.BlockSteelifier.updateFurnaceBlockState(BlockSteelifier.java:197) ~[blockSteelifier.class:?]
at freshpower.blocks.steelifier.TileEntitySteelifier.updateEntity(TileEntitySteelifier.java:303) ~[TileEntitySteelifier.class:?]
at net.minecraft.world.World.updateEntities(World.java:2148) ~[World.class:?]
at net.minecraft.world.WorldServer.updateEntities(WorldServer.java:536) ~[WorldServer.class:?]
at net.minecraft.server.MinecraftServer.updateTimeLightAndEntities(MinecraftServer.java:739) ~[MinecraftServer.class:?]

 

The BlockSteelifier line pointed to is:

par1World.setBlock(par2, par3, par4, FreshPower.getBlock("fp_steelifierActive"));

under the method

public static void updateFurnaceBlockState(boolean par0, World par1World, int par2, int par3, int par4)

 

The TileEntitySteelifer line is:

BlockSteelifier.updateFurnaceBlockState(this.furnaceBurnTime > 0, this.worldObj, this.xCoord, this.yCoord, this.zCoord);

under the method

public void updateEntity()

 

I think the error log has something to do with the entity updating. The error occurs when the block has sufficient stuff in the slots to "smelt". But nothing smelts, the block doesn't change to the illuminated one and this error pops up. Moments after, I get kicked out server given a TimeOutException.

Anyone know how to fix this. I know this code pointed at is identical to the BlockFurnace one, so I was wondering if vanilla Minecraft has a way of dealing with this for the vanilla Furnace and therefore available for me to use.

 

Thanks in advance.

 

 

Link to comment
Share on other sites

Do you remember if you messed with

if (!this.worldObj.isRemote) 

in your

TileEntitySteelifer

class?

 

As I understand it, the (!this.worldObj.isRemote) is needed to keep the client and server objects in the right places; if that is not in the right place, objects won't be available where they are needed.

 

I had a tough time getting my mod elements all to behave well between client and server if that was not used appropriately. (I still don't yet completely understand it.)

 

I would have suggested your getBlock() function, but if it worked in single player, your

FreshPower.getBlock("fp_steelifierActive")

should be working correctly.

 

What does your getBlock() function look like?

Link to comment
Share on other sites

Do you remember if you messed with

if (!this.worldObj.isRemote) 

in your

TileEntitySteelifer

class?

 

As I understand it, the (!this.worldObj.isRemote) is needed to keep the client and server objects in the right places; if that is not in the right place, objects won't be available where they are needed.

 

I had a tough time getting my mod elements all to behave well between client and server if that was not used appropriately. (I still don't yet completely understand it.)

 

I would have suggested your getBlock() function, but if it worked in single player, your

FreshPower.getBlock("fp_steelifierActive")

should be working correctly.

 

What does your getBlock() function look like?

Hi

 

The problem is caused by this line on the server

FreshPower.getBlock("fp_steelifierActive")

 

For some reason your getBlock is returning null.

 

-TGG

Thank you both. I figured it out now. My getBlock() method was returning null. I got it pointing in the right direction in the end. Thank you again.

And @mjhotdog, I don't think there were many or any for that matter of those isRemote booleans in the vanilla code, but thanks for mentioning this as usually I miss these out.

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.