fix: send empty NBT tag on items without NBT data (fixes #66)

(cherry picked from commit 5bcc72b911)
This commit is contained in:
mworzala 2023-10-17 01:09:41 -04:00 committed by Matt Worzala
parent 061c2c98f1
commit 941390fb87

View File

@ -236,7 +236,12 @@ final class NetworkBufferTypes {
buffer.nbtWriter = nbtWriter; buffer.nbtWriter = nbtWriter;
} }
try { try {
nbtWriter.writeNamed("", value); if (value == NBTEnd.INSTANCE) {
// Kotlin - https://discord.com/channels/706185253441634317/706186227493109860/1163703658341478462
buffer.write(BYTE, (byte) NBTType.TAG_End.getOrdinal());
} else {
nbtWriter.writeNamed("", value);
}
} catch (IOException e) { } catch (IOException e) {
throw new RuntimeException(e); throw new RuntimeException(e);
} }
@ -312,7 +317,10 @@ final class NetworkBufferTypes {
buffer.write(BOOLEAN, true); buffer.write(BOOLEAN, true);
buffer.write(VAR_INT, value.material().id()); buffer.write(VAR_INT, value.material().id());
buffer.write(BYTE, (byte) value.amount()); buffer.write(BYTE, (byte) value.amount());
buffer.write(NBT, value.meta().toNBT());
// Vanilla does not write an empty object, just an end tag.
NBTCompound nbt = value.meta().toNBT();
buffer.write(NBT, nbt.isEmpty() ? NBTEnd.INSTANCE : nbt);
return -1; return -1;
}, },
buffer -> { buffer -> {