mirror of
https://github.com/unmojang/node-minecraft-protocol.git
synced 2025-09-27 13:14:41 -04:00
Merge pull request #346 from deathcap/lengthprefixednbt
Add compressedNbt data type, used in MC 1.7
This commit is contained in:
commit
88c20cf795
@ -1,10 +1,12 @@
|
||||
const nbt = require('prismarine-nbt');
|
||||
const UUID = require('uuid-1345');
|
||||
const zlib = require('zlib');
|
||||
|
||||
module.exports = {
|
||||
'UUID': [readUUID, writeUUID, 16],
|
||||
'nbt': [readNbt, writeNbt, sizeOfNbt],
|
||||
'optionalNbt':[readOptionalNbt,writeOptionalNbt,sizeOfOptionalNbt],
|
||||
'compressedNbt':[readCompressedNbt,writeCompressedNbt,sizeOfCompressedNbt],
|
||||
'restBuffer': [readRestBuffer, writeRestBuffer, sizeOfRestBuffer],
|
||||
'entityMetadataLoop': [readEntityMetadata, writeEntityMetadata, sizeOfEntityMetadata]
|
||||
};
|
||||
@ -54,6 +56,35 @@ function sizeOfOptionalNbt(value) {
|
||||
return nbt.proto.sizeOf(value,"nbt");
|
||||
}
|
||||
|
||||
// Length-prefixed compressed NBT, see differences: http://wiki.vg/index.php?title=Slot_Data&diff=6056&oldid=4753
|
||||
function readCompressedNbt(buffer, offset) {
|
||||
const length = buffer.readInt16BE(offset);
|
||||
if(length == -1) return {size:2};
|
||||
|
||||
const compressedNbt = buffer.slice(offset+2, offset+2+length);
|
||||
|
||||
const nbtBuffer = zlib.gunzipSync(compressedNbt); // TODO: async
|
||||
|
||||
return nbt.proto.read(nbtBuffer,0,"nbt");
|
||||
}
|
||||
|
||||
function writeCompressedNbt(value, buffer, offset) {
|
||||
if(value==undefined) {
|
||||
buffer.writeInt16BE(-1,offset);
|
||||
return offset+2;
|
||||
}
|
||||
buffer.writeInt16(sizeOfNbt(value),offset);
|
||||
return nbt.proto.write(value,buffer,offset+2,"nbt");
|
||||
}
|
||||
|
||||
function sizeOfCompressedNbt(value) {
|
||||
if(value==undefined)
|
||||
return 2;
|
||||
return 2+nbt.proto.sizeOf(value,"nbt");
|
||||
}
|
||||
|
||||
|
||||
|
||||
function readRestBuffer(buffer, offset) {
|
||||
return {
|
||||
value: buffer.slice(offset),
|
||||
|
Loading…
x
Reference in New Issue
Block a user