Jump to content

Null Pointer Exception on NBT


TLHPoE

Recommended Posts

Hmm, can you try checking if the player object is valid?

 

EntityPlayer player = (EntityPlayer) event.entity;

if (player != null)
{
    // do stuff
}
else
{
    // oops
}

 

Another thing you could try is just using the entity itself since EntityJoinWorldEvent has a public field called world

 

if (event.entity instanceof EntityPlayer)
{
    event.entity.world;
}
else
{
    // oops
}

Link to comment
Share on other sites

Isn't

 

EntityPlayer player = (EntityPlayer)event.entity;

if(player != null){}

 

the same as

 

if (event.entity instanceof EntityPlayer){}

 

 

???

 

 

 

Also, I did that event.world, I created a world and crashed.

 

Error

 

 

2013-09-13 22:51:32 [iNFO] [sTDERR] java.lang.NullPointerException

2013-09-13 22:51:32 [iNFO] [sTDERR] at terramagna.utils.PlayerStatsUtil.onEntityJoinWorld(PlayerStatsUtil.java:27)

2013-09-13 22:51:32 [iNFO] [sTDERR] at net.minecraftforge.event.ASMEventHandler_5_PlayerStatsUtil_onEntityJoinWorld_EntityJoinWorldEvent.invoke(.dynamic)

2013-09-13 22:51:32 [iNFO] [sTDERR] at net.minecraftforge.event.ASMEventHandler.invoke(ASMEventHandler.java:39)

2013-09-13 22:51:32 [iNFO] [sTDERR] at net.minecraftforge.event.EventBus.post(EventBus.java:108)

2013-09-13 22:51:32 [iNFO] [sTDERR] at net.minecraft.world.World.spawnEntityInWorld(World.java:1572)

2013-09-13 22:51:32 [iNFO] [sTDERR] at net.minecraft.server.management.ServerConfigurationManager.playerLoggedIn(ServerConfigurationManager.java:267)

2013-09-13 22:51:32 [iNFO] [sTDERR] at net.minecraft.server.management.ServerConfigurationManager.initializeConnectionToPlayer(ServerConfigurationManager.java:136)

2013-09-13 22:51:32 [iNFO] [sTDERR] at net.minecraft.server.integrated.IntegratedServerListenThread.networkTick(IntegratedServerListenThread.java:97)

2013-09-13 22:51:32 [iNFO] [sTDERR] at net.minecraft.server.MinecraftServer.updateTimeLightAndEntities(MinecraftServer.java:689)

2013-09-13 22:51:32 [iNFO] [sTDERR] at net.minecraft.server.MinecraftServer.tick(MinecraftServer.java:585)

2013-09-13 22:51:32 [iNFO] [sTDERR] at net.minecraft.server.integrated.IntegratedServer.tick(IntegratedServer.java:129)

2013-09-13 22:51:32 [iNFO] [sTDERR] at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:482)

2013-09-13 22:51:32 [iNFO] [sTDERR] at net.minecraft.server.ThreadMinecraftServer.run(ThreadMinecraftServer.java:16)

2013-09-13 22:51:32 [sEVERE] [Minecraft-Server] Encountered an unexpected exception NullPointerException

java.lang.NullPointerException

at terramagna.utils.PlayerStatsUtil.onEntityJoinWorld(PlayerStatsUtil.java:27)

at net.minecraftforge.event.ASMEventHandler_5_PlayerStatsUtil_onEntityJoinWorld_EntityJoinWorldEvent.invoke(.dynamic)

at net.minecraftforge.event.ASMEventHandler.invoke(ASMEventHandler.java:39)

at net.minecraftforge.event.EventBus.post(EventBus.java:108)

at net.minecraft.world.World.spawnEntityInWorld(World.java:1572)

at net.minecraft.server.management.ServerConfigurationManager.playerLoggedIn(ServerConfigurationManager.java:267)

at net.minecraft.server.management.ServerConfigurationManager.initializeConnectionToPlayer(ServerConfigurationManager.java:136)

at net.minecraft.server.integrated.IntegratedServerListenThread.networkTick(IntegratedServerListenThread.java:97)

at net.minecraft.server.MinecraftServer.updateTimeLightAndEntities(MinecraftServer.java:689)

at net.minecraft.server.MinecraftServer.tick(MinecraftServer.java:585)

at net.minecraft.server.integrated.IntegratedServer.tick(IntegratedServer.java:129)

at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:482)

at net.minecraft.server.ThreadMinecraftServer.run(ThreadMinecraftServer.java:16)

2013-09-13 22:51:32 [sEVERE] [Minecraft-Server] This crash report has been saved to: C:\Users\Kavin\Desktop\Programming\Java\Modding\Operation Terra Magna\forge859\mcp\jars\.\crash-reports\crash-2013-09-13_22.51.32-server.txt

2013-09-13 22:51:32 [iNFO] [Minecraft-Server] Stopping server

2013-09-13 22:51:32 [iNFO] [Minecraft-Server] Saving players

2013-09-13 22:51:32 [iNFO] [Minecraft-Server] Player951 left the game

2013-09-13 22:51:32 [iNFO] [Minecraft-Server] Saving worlds

2013-09-13 22:51:32 [iNFO] [Minecraft-Server] Saving chunks for level 'New World'/Overworld

2013-09-13 22:51:32 [iNFO] [sTDOUT] ---- Minecraft Crash Report ----

2013-09-13 22:51:32 [iNFO] [sTDOUT] // I'm sorry, Dave.

2013-09-13 22:51:32 [iNFO] [sTDOUT]

2013-09-13 22:51:32 [iNFO] [sTDOUT] Time: 9/13/13 10:51 PM

2013-09-13 22:51:32 [iNFO] [sTDOUT] Description: Exception in server tick loop

2013-09-13 22:51:32 [iNFO] [sTDOUT]

2013-09-13 22:51:32 [iNFO] [sTDOUT] java.lang.NullPointerException

2013-09-13 22:51:32 [iNFO] [sTDOUT] at terramagna.utils.PlayerStatsUtil.onEntityJoinWorld(PlayerStatsUtil.java:27)

2013-09-13 22:51:32 [iNFO] [sTDOUT] at net.minecraftforge.event.ASMEventHandler_5_PlayerStatsUtil_onEntityJoinWorld_EntityJoinWorldEvent.invoke(.dynamic)

2013-09-13 22:51:32 [iNFO] [sTDOUT] at net.minecraftforge.event.ASMEventHandler.invoke(ASMEventHandler.java:39)

2013-09-13 22:51:32 [iNFO] [sTDOUT] at net.minecraftforge.event.EventBus.post(EventBus.java:108)

2013-09-13 22:51:32 [iNFO] [sTDOUT] at net.minecraft.world.World.spawnEntityInWorld(World.java:1572)

2013-09-13 22:51:32 [iNFO] [sTDOUT] at net.minecraft.server.management.ServerConfigurationManager.playerLoggedIn(ServerConfigurationManager.java:267)

2013-09-13 22:51:32 [iNFO] [sTDOUT] at net.minecraft.server.management.ServerConfigurationManager.initializeConnectionToPlayer(ServerConfigurationManager.java:136)

2013-09-13 22:51:32 [iNFO] [sTDOUT] at net.minecraft.server.integrated.IntegratedServerListenThread.networkTick(IntegratedServerListenThread.java:97)

2013-09-13 22:51:32 [iNFO] [sTDOUT] at net.minecraft.server.MinecraftServer.updateTimeLightAndEntities(MinecraftServer.java:689)

2013-09-13 22:51:32 [iNFO] [sTDOUT] at net.minecraft.server.MinecraftServer.tick(MinecraftServer.java:585)

2013-09-13 22:51:32 [iNFO] [sTDOUT] at net.minecraft.server.integrated.IntegratedServer.tick(IntegratedServer.java:129)

2013-09-13 22:51:32 [iNFO] [sTDOUT] at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:482)

2013-09-13 22:51:32 [iNFO] [sTDOUT] at net.minecraft.server.ThreadMinecraftServer.run(ThreadMinecraftServer.java:16)

 

 

 

 

http://pastebin.com/yzFYunLL

Kain

Link to comment
Share on other sites

Yes, those two code blocks are essentially the same. Some people prefer to not cast from one class to the other so pick whichever fits your code style.

 

As for the newest crash, you should check if the world is null before trying to use it. It's possible that the world field in EntityJoinWorldEvent() hasn't been set before your override gets called.

 

Also, try using event.entity.worldObj and see if that is null.

Link to comment
Share on other sites

Try using this in your EntityJoinWorldEvent instead:

if (event.entity instanceof EntityPlayer) {
  event.entity.getEntityData().setInteger("gold", 1000);
  // test to see if it worked:
  System.out.println("Player's gold: " + event.entity.getEntityData().getInteger("gold"));
}

'getEntityData()' returns the NBT Tag Compound associated with the entity, be it player or whatever. Then you can set the gold directly like that if you want.

 

You don't need to create all those other variables in your code, such as 'theNBT'. Just use the ones provided by the parameters.

Link to comment
Share on other sites

Try using this in your EntityJoinWorldEvent instead:

if (event.entity instanceof EntityPlayer) {
  event.entity.getEntityData().setInteger("gold", 1000);
  // test to see if it worked:
  System.out.println("Player's gold: " + event.entity.getEntityData().getInteger("gold"));
}

'getEntityData()' returns the NBT Tag Compound associated with the entity, be it player or whatever. Then you can set the gold directly like that if you want.

 

You don't need to create all those other variables in your code, such as 'theNBT'. Just use the ones provided by the parameters.

 

The OP is using that event. I think the problem is that those objects have not been set yet when he / she is trying to access them.

 

It's similar to how you can't access worldObj in the constructor of a TileEntity because it does not get set until after the constructor.

Link to comment
Share on other sites

Try using this in your EntityJoinWorldEvent instead:

if (event.entity instanceof EntityPlayer) {
  event.entity.getEntityData().setInteger("gold", 1000);
  // test to see if it worked:
  System.out.println("Player's gold: " + event.entity.getEntityData().getInteger("gold"));
}

'getEntityData()' returns the NBT Tag Compound associated with the entity, be it player or whatever. Then you can set the gold directly like that if you want.

 

You don't need to create all those other variables in your code, such as 'theNBT'. Just use the ones provided by the parameters.

 

The OP is using that event. I think the problem is that those objects have not been set yet when he / she is trying to access them.

 

It's similar to how you can't access worldObj in the constructor of a TileEntity because it does not get set until after the constructor.

All of those fields should already be initialized in EntityJoinWorldEvent. I use it all the time to set IExtendedEntityProperty data specifically because these same objects are available for use, whereas, as you've pointed out, are NOT available in a constructor or using the EntityConstructingEvent.

 

@OP: I'd suggest taking a look at my tutorial on using IExtendedEntityProperties - there you will find a better way to add gold as well as get it to persist across player death and such. http://www.minecraftforum.net/topic/1952901-eventhandler-and-iextendedentityproperties/#entry24051513

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

    • I can’t see what the problem is since there seem to be no errors. Are you sure that was everything? The last log seems to be about the graphics library. Maybe that is the issue.  [20:26:39] [main/INFO]: Incorrect key [earlyWindowSkipGLVersions] was corrected from null to [] …… [20:26:41] [main/INFO]: Trying GL version 4.6 looks sus, but it might not be the issue
    • setDeltaMovement only works on the client. this makes the animations smoother. The reason sendSystemMessage works is because you don’t have to constantly send messages from the server to the client, and a little bit of lag is ok. This is a core minecraft mechanism, but you can send custom packets over to the client to set its deltaMovement. The client has to have a way to receive the packets too.
    • The full log is this What do I do? [20:26:39] [main/INFO]: ModLauncher running: args [--username, xYumixks, --version, forge-47.2.32, --gameDir, C:\Users\danil\curseforge\minecraft\Instances\mine guerra 2, --assetsDir, C:\Users\danil\curseforge\minecraft\Install\assets, --assetIndex, 5, --uuid, 979909db94104f33a94abdc77f4cc574, --accessToken, ????????, --clientId, NzI5M2NmYmUtZWI3Ni00MWVlLWFhZTgtODUzMTFjZTVkYTM0, --xuid, 2535414120491579, --userType, msa, --versionType, release, --width, 1024, --height, 768, --quickPlayPath, C:\Users\danil\curseforge\minecraft\Install\quickPlay\java\1715815597218.json, --launchTarget, forgeclient, --fml.forgeVersion, 47.2.32, --fml.mcVersion, 1.20.1, --fml.forgeGroup, net.minecraftforge, --fml.mcpVersion, 20230612.114412] [20:26:39] [main/INFO]: ModLauncher 10.0.9+10.0.9+main.dcd20f30 starting: java version 17.0.8 by Microsoft; OS Windows 11 arch amd64 version 10.0 [20:26:39] [main/WARN]: Configuration file C:\Users\danil\curseforge\minecraft\Instances\mine guerra 2\config\fml.toml is not correct. Correcting [20:26:39] [main/INFO]: Incorrect key [earlyWindowSkipGLVersions] was corrected from null to [] [20:26:39] [main/INFO]: Incorrect key [earlyWindowSquir] was corrected from null to false [20:26:39] [main/INFO]: Incorrect key [earlyWindowShowCPU] was corrected from null to false [20:26:41] [main/INFO]: Loading ImmediateWindowProvider fmlearlywindow [20:26:41] [main/INFO]: Trying GL version 4.6
    • Try and replace () -> new Item(Item.properties….. in ModItems with  () -> new HoneyBottleItem(Item.properties……
    • Mouseclick event handler https://pastebin.com/EMciNkKe
  • Topics

×
×
  • Create New...

Important Information

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