Jump to content

Syncing ItemStack capabilities


Jay Avery

Recommended Posts

I have an ItemStack capability which makes an item decay over time, by storing the 'birth time' of the item to use for checks (discussed a bit more here). I'm struggling with syncing though, because ItemStack capabilities seem to be a nightmare.

 

When an ItemStack of my decaying item is first created, the server and client both make their new capability with the current world time which matches up as expected. But when an ItemStack is split or changed in some way, the server keeps its information but the client makes a new capability with a new 'birth time' of the current world time. I'm assuming this is related to all the weirdness about how Forge sends vanilla packets when capabilities change but doesn't actually update the capability (unless my information is outdated, and this problem has been solved?).

 

Anyway, my question is: where (when) should I sync my ItemStack capabilities from server to client, and how? They only need to sync when they're actually created - the 'birth time' of the stack is set when it's born and then never changes, so they don't need to be updated every tick or anything. But ItemStacks are created in so many different places, during copying, splitting, etc - I don't know how to make sure I am syncing at every possible time when it might be required. I thought about sending a packet in initCapabilities, but that method doesn't have any information about where the stack is located (inventory slot etc), so there's no way of knowing where it needs to be synced to. Can anyone advise?

Link to comment
Share on other sites

ItemStack capability syncing has been discussed quite a lot in GitHub issues (e,g, here and the issues/PRs linked by it), but there's no real resolution yet.

 

One method of syncing that works fairly well is a custom IContainerListener, as described in this thread. I recently implemented this for my mod's item capabilities here. One issue with this is that an item's capability data is completely reset when taking it out of the creative menu.

Edited by Choonster
  • Like 1

Please don't PM me to ask for help. Asking your question in a public thread preserves it for people who are having the same problem in the future.

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.