Jump to content

(1.18.2) desync block entity information (CompoundTag)


ElTotisPro50

Recommended Posts

When I say information i mean strings, booleans, integers; saved in the block entity

I made a block entity that can teleport me to 8 different saved locations, but for some reason, the information that i put from the screen to the block entity synchronizes with other places block entities, if i place one, break it and place it again the information should remove, but it doesnt. And if i place 2 or more block entities and modify one of them, the other one modifies too, basically like an ender chest, they sync with each-other and that SHOULD NOT happen (Video: https://imgur.com/a/viFLTRy)

I spent days looking at the code and i cant find the bug lol

BTW: the code is not clean and obviously is bad written, but right now my priority is to solve this problem; later, i will clean the code

 

WarpPipeBlockEntity: https://pastebin.com/mGCNHwwm

TeleporterMenu: https://pastebin.com/ZdwJ8DvP

TeleporterScreen: https://pastebin.com/HELZBAqQ

TeleportCrystalItem: https://pastebin.com/8fD9wkdW

PacketSyncTeleporterPosToClient: https://pastebin.com/RNyY1miv

ModMessages: https://pastebin.com/Zw0ShuLs

Link to comment
Share on other sites

Just now, ChampionAsh5357 said:

Makes sense, all of your fields are static, so they would be shared across all instances.

I solved that, but now, I can't send information from screen to blockentity, it doesnt crash or anything, it just doesnt send what i need

TeleporterScreen: https://pastebin.com/Qbp4GKK0

WarpPipeBlockEntity: https://pastebin.com/s6dXa7EX

PacketSyncTeleporter2S: https://pastebin.com/u0S1jDx8

PacketSyncTeleporterPosToClient: https://pastebin.com/7A0Wccfc

Link to comment
Share on other sites

1 minute ago, ElTotisPro50 said:

I solved that, but now, I can't send information from screen to blockentity, it doesnt crash or anything, it just doesnt send what i need

Could you define doesn't send what you need? From what I'm looking at, all I can see is that you're trying to sync everything to the block entity client when creating the menu, which is an idea and should roughly work, but doesn't help me understand the issue. Additionally, I think breakpoints would be really helpful here so you can view what your own code is doing.

Link to comment
Share on other sites

2 hours ago, ChampionAsh5357 said:

Could you define doesn't send what you need? From what I'm looking at, all I can see is that you're trying to sync everything to the block entity client when creating the menu, which is an idea and should roughly work, but doesn't help me understand the issue. Additionally, I think breakpoints would be really helpful here so you can view what your own code is doing.

I still cant figure it out, im trying to pass the variables from the screen to the block entity, actually, if i pass the values without sending them to the server with a package, it works, but if i close the menu and open it again the information removes

public void savePos(int q) {
		ItemStack item = menu.getBlockEntity().getItemFromSlot(0);
		CompoundTag tag = item.getTag();
		if(tag != null && tag.contains("hasInfo")) {
			String name = (!item.hasCustomHoverName()) ? "" : TotisPlayerUtils.getItemDisplayName(item);
			//ModMessages.sendToServer(new PacketSyncTeleporter2S(q, tag.getInt("x"),tag.getInt("y"),tag.getInt("z"), q, true, tag.getString(Constants.DIMENSION), name, menu.getBlockEntity().getBlockPos()));
			menu.getBlockEntity().setPosX(tag.getInt("x"), q);
			menu.getBlockEntity().setPosY(tag.getInt("y"), q);
			menu.getBlockEntity().setPosZ(tag.getInt("z"), q);
			menu.getBlockEntity().setSelectedWheelPart(q);
			menu.getBlockEntity().setDestName(q,name);
			menu.getBlockEntity().setDestExists(q,true);
			menu.getBlockEntity().setDestDimension(q,tag.getString(Constants.DIMENSION));
			player.sendMessage(new TextComponent("Saved position in space "+q), player.getUUID());
        }
}

 

Link to comment
Share on other sites

11 minutes ago, ElTotisPro50 said:

I still cant figure it out, im trying to pass the variables from the screen to the block entity, actually, if i pass the values without sending them to the server with a package, it works, but if i close the menu and open it again the information removes

Are you sure the block entity on the client has the correct position? Additionally, you're reading the sent data to the server incorrectly. The order you write the bytes must be the order your read them.

Link to comment
Share on other sites

1 minute ago, ChampionAsh5357 said:

Are you sure the block entity on the client has the correct position? Additionally, you're reading the sent data to the server incorrectly. The order you write the bytes must be the order your read them.

 

3 minutes ago, ChampionAsh5357 said:

Are you sure the block entity on the client has the correct position?

menu.getBlockEntity().getBlockPos() is the default method that gets the worldposition of the block entity, i checked just in case, and the position is correct: player.sendMessage(new TextComponent(menu.getBlockEntity().getBlockPos().getX()+","+menu.getBlockEntity().getBlockPos().getY()+","+menu.getBlockEntity().getBlockPos().getZ()), player.getUUID());

 

 

with "The order you write the bytes must be the order your read them." you mean i have to order the readers and writers in the constructor's order?

public PacketSyncTeleporter2S(
            int dest, int x,int y,int z, int selected, boolean exists, String dimension, String name, BlockPos pos) {
        this.blockPos = pos;
        this.exists = exists;
        this.name = name;
        this.dimension = dimension;
        this.dest = dest;
        this.x = x;
        this.y = y;
        this.z = z;
        this.selected = selected;
    }

//read
    public PacketSyncTeleporter2S(FriendlyByteBuf buf) {
        this.dimension = buf.readUtf();
        this.name = buf.readUtf();
        this.blockPos = buf.readBlockPos();
        this.x = buf.readInt();
        this.y = buf.readInt();
        this.z = buf.readInt();
        this.exists = buf.readBoolean();
        this.dest = buf.readInt();
        this.selected = buf.readInt();
    }

    //write
    public void toBytes(FriendlyByteBuf buf) {
        buf.writeInt(x);
        buf.writeInt(y);
        buf.writeInt(z);
        buf.writeInt(selected);
        buf.writeInt(dest);
        buf.writeUtf(dimension);
        buf.writeUtf(name);
        buf.writeBoolean(exists);
        buf.writeBlockPos(blockPos);
    }

 

Link to comment
Share on other sites

15 minutes ago, ElTotisPro50 said:

with "The order you write the bytes must be the order your read them." you mean i have to order the readers and writers in the constructor's order?

The #toBytes method must write the bytes in the same order as PacketSyncTeleporter2S(FriendlyByteBuf) reads them. Otherwise, you are reading inaccurate data which could affect some of the results.

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.



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • I'm opening the forge 1.8.9 installer properly I click install with the client option selected, it says it installs properly but when I go into my files and also when I go into the minecraft launcher, it's just not there.  JVM info: Oracle Corporation - 1.8.0_431 - 25.431-b10 java.net.preferIPv4Stack=true Found java version 1.8.0_431 Considering minecraft client jar Considering library net.minecraftforge:forge:1.8.9-11.15.1.2318-1.8.9: Not Downloading {Wrong Side} Considering library net.minecraft:launchwrapper:1.12: Not Downloading {Wrong Side} Considering library org.ow2.asm:asm-all:5.0.3: Not Downloading {Wrong Side} Considering library jline:jline:2.13: Not Downloading {Wrong Side} Considering library com.typesafe.akka:akka-actor_2.11:2.3.3 Considering library com.typesafe:config:1.2.1 Considering library org.scala-lang:scala-actors-migration_2.11:1.1.0 Considering library org.scala-lang:scala-compiler:2.11.1 Considering library org.scala-lang.plugins:scala-continuations-library_2.11:1.0.2 Considering library org.scala-lang.plugins:scala-continuations-plugin_2.11.1:1.0.2 Considering library org.scala-lang:scala-library:2.11.1 Considering library org.scala-lang:scala-parser-combinators_2.11:1.0.1 Considering library org.scala-lang:scala-reflect:2.11.1 Considering library org.scala-lang:scala-swing_2.11:1.0.1 Considering library org.scala-lang:scala-xml_2.11:1.0.2 Considering library lzma:lzma:0.0.1: Not Downloading {Wrong Side} Considering library net.sf.jopt-simple:jopt-simple:4.6: Not Downloading {Wrong Side} Considering library java3d:vecmath:1.5.2 Considering library net.sf.trove4j:trove4j:3.0.3 Extracting: /forge-1.8.9-11.15.1.2318-1.8.9-universal.jar To: C:\Users\Ian\AppData\Roaming\.minecraft\libraries\net\minecraftforge\forge\1.8.9-11.15.1.2318-1.8.9\forge-1.8.9-11.15.1.2318-1.8.9.jar That's the installer log and I have no idea if anything is wrong.
    • https://mclo.gs/NQ786zI   I don’t understand what I need to do.
    • I am wanting to give the armour in my mod special properties, but I have no idea how to do so.   For the first armour set I want it to be the case that when the full set is worn it has the properties of a carved pumpkin, making it so you won't aggravate endermen when you look at them.    The second, and presumably harder property is that for the second set I would like it to be the case that when the full set is worn, you can walk over the void without falling. (I was considering using the levitation to accomplish this but I wanted to check beforehand).   Would both of these specialities be achievable for each armour set and how exactly would they both be done? Help would be much appreciated. 
    • I finally got my Forge server up and running thanks to the help of the people on this forum and played fine for a day. Now since I started playing today, the server runs for 20-30 minutes then freezes and kicks everyone out but stays up and running but won't let anyone connect. Here is the latest debug log and crashlog from the server. Thank you for reading & helping   https://gist.github.com/Dwolfwoood/d0410e581c86772694f1d8007431c409   https://gist.github.com/Dwolfwoood/b5d521fd071dbfcc816949924757fef9
    • I got the infamous crash log that you get when you have a mod or multiple mods that are incompatible with the version being used. however.. I have no idea which ones are wrong. I was hoping the forums could help me figure it out. does the crsh report tell me and im just dumb?  
  • Topics

  • Who's Online (See full list)

    • There are no registered users currently online
×
×
  • Create New...

Important Information

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