Jump to content
View in the app

A better way to browse. Learn more.

Forge Forums

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Featured Replies

Posted

SOLUTION: Use the IMessageHandler#onMessage 'message' parameter to access the field, rather than trying to access the class field directly (it's a separate instance of the class when it processes the IMessageHandler vs the IMessage) - thanks jabelar!

 

Hi again,

 

I've run into an interesting problem - it seems that data stored in a message class is not available in the "onMessage" method. This is with Forge 10.12.2.1121 by the way.

 

Here is the code for my message:

 

public class SyncPlayerPropsMessage implements IMessage, IMessageHandler<SyncPlayerPropsMessage, IMessage>
{
private NBTTagCompound data;

public SyncPlayerPropsMessage() {}

public SyncPlayerPropsMessage(EntityPlayer player) {
data = new NBTTagCompound();
ExtendedPlayer.get(player).saveNBTData(data);
}

@Override
public void fromBytes(ByteBuf buffer) {
System.out.println("From Bytes... reading");
data = ByteBufUtils.readTag(buffer);
if (data == null) {
System.out.println("WARNING: Data read from buffer is NULL!!!");
}
}

@Override
public void toBytes(ByteBuf buffer) {
System.out.println("To Bytes... writing");
if (data == null) {
System.out.println("WARNING: Data to write is NULL!!!");
}
ByteBufUtils.writeTag(buffer, data);
}

@Override
public IMessage onMessage(SyncPlayerPropsMessage message, MessageContext ctx) {
if (data == null) {
System.out.println("WARNING: onMessage data is NULL!!!");
}
return null;
}

 

 

And console output from that:

To Bytes... writing
From Bytes... reading
WARNING: onMessage data is NULL!!!

 

As you can see, the data is not null before it is written, nor is it null after it is read, but whatever happens in between being read and processing onMessage, the data disappears!

 

In another message, I send a simple integer, and that one has the same problem. I thought it was working, but it was only because the value I sent was zero (the GUI index to open) - changing it to 10 failed to open a Gui.

 

Any ideas what could be going wrong here?

 

Thanks,

coolAlias

  • Author

I haven't played much with this, but why are you testing data == null instead of message.data == null?  Shouldn't you be trying to look at the data in the message passed as a parameter to that method?

Lol, you are totally right! I was thinking 'hey, it's in the same class, so the data will be there' wow. Derpety derp derp :P Thanks buddy!

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...

Important Information

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

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.