mirror of
https://github.com/PrismarineJS/node-minecraft-protocol.git
synced 2024-11-24 00:07:51 -05:00
Merge 60ba34dded
into 590dc33fed
This commit is contained in:
commit
3ad4a1f0b7
4 changed files with 161 additions and 3 deletions
1
.github/workflows/ci.yml
vendored
1
.github/workflows/ci.yml
vendored
|
@ -56,5 +56,6 @@ jobs:
|
||||||
distribution: 'adopt'
|
distribution: 'adopt'
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: npm install
|
run: npm install
|
||||||
|
- run: cd node_modules && cd minecraft-data && mv minecraft-data minecraft-data-old && git clone -b pc1.21.3 https://github.com/GroobleDierne/minecraft-data.git --depth 1 && node bin/generate_data.js
|
||||||
- name: Run tests
|
- name: Run tests
|
||||||
run: npm run mochaTest -- -g ${{ matrix.mcVersion }}v
|
run: npm run mochaTest -- -g ${{ matrix.mcVersion }}v
|
||||||
|
|
|
@ -13,7 +13,7 @@ Parse and serialize minecraft packets, plus authentication and encryption.
|
||||||
|
|
||||||
* Supports Minecraft PC version 1.7.10, 1.8.8, 1.9 (15w40b, 1.9, 1.9.1-pre2, 1.9.2, 1.9.4),
|
* Supports Minecraft PC version 1.7.10, 1.8.8, 1.9 (15w40b, 1.9, 1.9.1-pre2, 1.9.2, 1.9.4),
|
||||||
1.10 (16w20a, 1.10-pre1, 1.10, 1.10.1, 1.10.2), 1.11 (16w35a, 1.11, 1.11.2), 1.12 (17w15a, 17w18b, 1.12-pre4, 1.12, 1.12.1, 1.12.2), and 1.13 (17w50a, 1.13, 1.13.1, 1.13.2-pre1, 1.13.2-pre2, 1.13.2), 1.14 (1.14, 1.14.1, 1.14.3, 1.14.4)
|
1.10 (16w20a, 1.10-pre1, 1.10, 1.10.1, 1.10.2), 1.11 (16w35a, 1.11, 1.11.2), 1.12 (17w15a, 17w18b, 1.12-pre4, 1.12, 1.12.1, 1.12.2), and 1.13 (17w50a, 1.13, 1.13.1, 1.13.2-pre1, 1.13.2-pre2, 1.13.2), 1.14 (1.14, 1.14.1, 1.14.3, 1.14.4)
|
||||||
, 1.15 (1.15, 1.15.1, 1.15.2) and 1.16 (20w13b, 20w14a, 1.16-rc1, 1.16, 1.16.1, 1.16.2, 1.16.3, 1.16.4, 1.16.5), 1.17 (21w07a, 1.17, 1.17.1), 1.18 (1.18, 1.18.1 and 1.18.2), 1.19 (1.19, 1.19.1, 1.19.2, 1.19.3, 1.19.4, 1.20, 1.20.1, 1.20.2, 1.20.3, 1.20.4, 1.20.5, 1.20.6, 1.21.1)
|
, 1.15 (1.15, 1.15.1, 1.15.2) and 1.16 (20w13b, 20w14a, 1.16-rc1, 1.16, 1.16.1, 1.16.2, 1.16.3, 1.16.4, 1.16.5), 1.17 (21w07a, 1.17, 1.17.1), 1.18 (1.18, 1.18.1 and 1.18.2), 1.19 (1.19, 1.19.1, 1.19.2, 1.19.3, 1.19.4), 1.20 (1.20, 1.20.1, 1.20.2, 1.20.3, 1.20.4, 1.20.5, 1.20.6), 1.21 (1.21, 1.21.1, 1.21.3)
|
||||||
* Parses all packets and emits events with packet fields as JavaScript
|
* Parses all packets and emits events with packet fields as JavaScript
|
||||||
objects.
|
objects.
|
||||||
* Send a packet by supplying fields as a JavaScript object.
|
* Send a packet by supplying fields as a JavaScript object.
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
/* eslint-disable no-return-assign */
|
||||||
const UUID = require('uuid-1345')
|
const UUID = require('uuid-1345')
|
||||||
const minecraft = require('./minecraft')
|
const minecraft = require('./minecraft')
|
||||||
|
|
||||||
|
@ -41,7 +42,7 @@ module.exports = {
|
||||||
code += '}'
|
code += '}'
|
||||||
return compiler.wrapCode(code)
|
return compiler.wrapCode(code)
|
||||||
}],
|
}],
|
||||||
arrayWithLengthOffset: ['parametrizable', (compiler, array) => {
|
arrayWithLengthOffset: ['parametrizable', (compiler, array) => { // TODO: remove
|
||||||
let code = ''
|
let code = ''
|
||||||
if (array.countType) {
|
if (array.countType) {
|
||||||
code += 'const { value: count, size: countSize } = ' + compiler.callType(array.countType) + '\n'
|
code += 'const { value: count, size: countSize } = ' + compiler.callType(array.countType) + '\n'
|
||||||
|
@ -61,6 +62,56 @@ module.exports = {
|
||||||
code += '}\n'
|
code += '}\n'
|
||||||
code += 'return { value: data, size }'
|
code += 'return { value: data, size }'
|
||||||
return compiler.wrapCode(code)
|
return compiler.wrapCode(code)
|
||||||
|
}],
|
||||||
|
bitflags: ['parametrizable', (compiler, { type, flags, shift, big }) => {
|
||||||
|
let fstr = JSON.stringify(flags)
|
||||||
|
if (Array.isArray(flags)) {
|
||||||
|
fstr = '{'
|
||||||
|
for (const [k, v] of Object.entries(flags)) fstr += `"${v}": ${big ? (1n << BigInt(k)) : (1 << k)}` + (big ? 'n,' : ',')
|
||||||
|
fstr += '}'
|
||||||
|
} else if (shift) {
|
||||||
|
fstr = '{'
|
||||||
|
for (const key in flags) fstr += `"${key}": ${1 << flags[key]},`
|
||||||
|
fstr += '}'
|
||||||
|
}
|
||||||
|
return compiler.wrapCode(`
|
||||||
|
const { value: _value, size } = ${compiler.callType(type, 'offset')}
|
||||||
|
const value = { _value }
|
||||||
|
const flags = ${fstr}
|
||||||
|
for (const key in flags) {
|
||||||
|
value[key] = (_value & flags[key]) == flags[key]
|
||||||
|
}
|
||||||
|
return { value, size }
|
||||||
|
`.trim())
|
||||||
|
}],
|
||||||
|
registryEntryHolder: ['parametrizable', (compiler, opts) => {
|
||||||
|
return compiler.wrapCode(`
|
||||||
|
const { value: n, size: nSize } = ${compiler.callType('varint')}
|
||||||
|
if (n !== 0) {
|
||||||
|
return { value: { ${opts.baseName}: n - 1 }, size: nSize }
|
||||||
|
} else {
|
||||||
|
const holder = ${compiler.callType(opts.otherwise.type)}
|
||||||
|
return { value: { ${opts.otherwise.name}: holder.data }, size: nSize + holder.size }
|
||||||
|
}
|
||||||
|
`.trim())
|
||||||
|
}],
|
||||||
|
registryEntryHolderSet: ['parametrizable', (compiler, opts) => {
|
||||||
|
return compiler.wrapCode(`
|
||||||
|
const { value: n, size: nSize } = ${compiler.callType('varint')}
|
||||||
|
if (n === 0) {
|
||||||
|
const base = ${compiler.callType(opts.base.type)}
|
||||||
|
return { value: { ${opts.base.name}: base.value }, size: base.size + nSize }
|
||||||
|
} else {
|
||||||
|
const set = []
|
||||||
|
let accSize = nSize
|
||||||
|
for (let i = 0; i < n - 1; i++) {
|
||||||
|
const entry = ${compiler.callType(opts.otherwise.type)}
|
||||||
|
set.push(entry.value)
|
||||||
|
accSize += entry.size
|
||||||
|
}
|
||||||
|
return { value: { ${opts.otherwise.name}: set }, size: accSize }
|
||||||
|
}
|
||||||
|
`.trim())
|
||||||
}]
|
}]
|
||||||
},
|
},
|
||||||
Write: {
|
Write: {
|
||||||
|
@ -106,6 +157,58 @@ module.exports = {
|
||||||
code += '}\n'
|
code += '}\n'
|
||||||
code += 'return offset'
|
code += 'return offset'
|
||||||
return compiler.wrapCode(code)
|
return compiler.wrapCode(code)
|
||||||
|
}],
|
||||||
|
bitflags: ['parametrizable', (compiler, { type, flags, shift, big }) => {
|
||||||
|
let fstr = JSON.stringify(flags)
|
||||||
|
if (Array.isArray(flags)) {
|
||||||
|
fstr = '{'
|
||||||
|
for (const [k, v] of Object.entries(flags)) fstr += `"${v}": ${big ? (1n << BigInt(k)) : (1 << k)}` + (big ? 'n,' : ',')
|
||||||
|
fstr += '}'
|
||||||
|
} else if (shift) {
|
||||||
|
fstr = '{'
|
||||||
|
for (const key in flags) fstr += `"${key}": ${1 << flags[key]},`
|
||||||
|
fstr += '}'
|
||||||
|
}
|
||||||
|
return compiler.wrapCode(`
|
||||||
|
const flags = ${fstr}
|
||||||
|
let val = value._value ${big ? '|| 0n' : ''}
|
||||||
|
for (const key in flags) {
|
||||||
|
if (value[key]) val |= flags[key]
|
||||||
|
}
|
||||||
|
return (ctx.${type})(val, buffer, offset)
|
||||||
|
`.trim())
|
||||||
|
}],
|
||||||
|
registryEntryHolder: ['parametrizable', (compiler, opts) => {
|
||||||
|
const baseName = `value.${opts.baseName}`
|
||||||
|
const otherwiseName = `value.${opts.otherwise.name}`
|
||||||
|
return compiler.wrapCode(`
|
||||||
|
if (${baseName}) {
|
||||||
|
offset = ${compiler.callType(`${baseName} + 1`, 'varint')}
|
||||||
|
} else if (${otherwiseName}) {
|
||||||
|
offset = ${compiler.callType(`${otherwiseName}`, opts.otherwise.type)}
|
||||||
|
} else {
|
||||||
|
throw new Error('registryEntryHolder type requires "${baseName}" or "${otherwiseName}" fields to be set')
|
||||||
|
}
|
||||||
|
return offset
|
||||||
|
`.trim())
|
||||||
|
}],
|
||||||
|
registryEntryHolderSet: ['parametrizable', (compiler, opts) => {
|
||||||
|
const baseName = `value.${opts.base.name}`
|
||||||
|
const otherwiseName = `value.${opts.otherwise.name}`
|
||||||
|
return compiler.wrapCode(`
|
||||||
|
if (${baseName}) {
|
||||||
|
offset = ${compiler.callType(0, 'varint')}
|
||||||
|
offset = ${compiler.callType(`${baseName}`, opts.base.type)}
|
||||||
|
} else if (${otherwiseName}) {
|
||||||
|
offset = ${compiler.callType(`${otherwiseName}.length + 1`, 'varint')}
|
||||||
|
for (let i = 0; i < ${otherwiseName}.length; i++) {
|
||||||
|
offset = ${compiler.callType(opts.otherwise.type)}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
throw new Error('registryEntryHolder type requires "${baseName}" or "${otherwiseName}" fields to be set')
|
||||||
|
}
|
||||||
|
return offset
|
||||||
|
`.trim())
|
||||||
}]
|
}]
|
||||||
},
|
},
|
||||||
SizeOf: {
|
SizeOf: {
|
||||||
|
@ -149,6 +252,60 @@ module.exports = {
|
||||||
}
|
}
|
||||||
code += 'return size'
|
code += 'return size'
|
||||||
return compiler.wrapCode(code)
|
return compiler.wrapCode(code)
|
||||||
|
}],
|
||||||
|
bitflags: ['parametrizable', (compiler, { type, flags, shift, big }) => {
|
||||||
|
let fstr = JSON.stringify(flags)
|
||||||
|
if (Array.isArray(flags)) {
|
||||||
|
fstr = '{'
|
||||||
|
for (const [k, v] of Object.entries(flags)) fstr += `"${v}": ${big ? (1n << BigInt(k)) : (1 << k)}` + (big ? 'n,' : ',')
|
||||||
|
fstr += '}'
|
||||||
|
} else if (shift) {
|
||||||
|
fstr = '{'
|
||||||
|
for (const key in flags) fstr += `"${key}": ${1 << flags[key]},`
|
||||||
|
fstr += '}'
|
||||||
|
}
|
||||||
|
return compiler.wrapCode(`
|
||||||
|
const flags = ${fstr}
|
||||||
|
let val = value._value ${big ? '|| 0n' : ''}
|
||||||
|
for (const key in flags) {
|
||||||
|
if (value[key]) val |= flags[key]
|
||||||
|
}
|
||||||
|
return (ctx.${type})(val)
|
||||||
|
`.trim())
|
||||||
|
}],
|
||||||
|
registryEntryHolder: ['parametrizable', (compiler, opts) => {
|
||||||
|
const baseName = `value.${opts.baseName}`
|
||||||
|
const otherwiseName = `value.${opts.otherwise.name}`
|
||||||
|
return compiler.wrapCode(`
|
||||||
|
let size = 0
|
||||||
|
if (${baseName}) {
|
||||||
|
size += ${compiler.callType(`${baseName} + 1`, 'varint')}
|
||||||
|
} else if (${otherwiseName}) {
|
||||||
|
size += ${compiler.callType(`${otherwiseName}`, opts.otherwise.type)}
|
||||||
|
} else {
|
||||||
|
throw new Error('registryEntryHolder type requires "${baseName}" or "${otherwiseName}" fields to be set')
|
||||||
|
}
|
||||||
|
return size
|
||||||
|
`.trim())
|
||||||
|
}],
|
||||||
|
registryEntryHolderSet: ['parametrizable', (compiler, opts) => {
|
||||||
|
const baseName = `value.${opts.base.name}`
|
||||||
|
const otherwiseName = `value.${opts.otherwise.name}`
|
||||||
|
return compiler.wrapCode(`
|
||||||
|
let size = 0
|
||||||
|
if (${baseName}) {
|
||||||
|
size += ${compiler.callType(0, 'varint')}
|
||||||
|
size += ${compiler.callType(`${baseName}`, opts.base.type)}
|
||||||
|
} else if (${otherwiseName}) {
|
||||||
|
size += ${compiler.callType(`${otherwiseName}.length + 1`, 'varint')}
|
||||||
|
for (let i = 0; i < ${otherwiseName}.length; i++) {
|
||||||
|
size += ${compiler.callType(opts.otherwise.type)}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
throw new Error('registryEntryHolder type requires "${baseName}" or "${otherwiseName}" fields to be set')
|
||||||
|
}
|
||||||
|
return size
|
||||||
|
`.trim())
|
||||||
}]
|
}]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,5 +2,5 @@
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
defaultVersion: '1.21.1',
|
defaultVersion: '1.21.1',
|
||||||
supportedVersions: ['1.7', '1.8.8', '1.9.4', '1.10.2', '1.11.2', '1.12.2', '1.13.2', '1.14.4', '1.15.2', '1.16.5', '1.17.1', '1.18.2', '1.19', '1.19.2', '1.19.3', '1.19.4', '1.20', '1.20.1', '1.20.2', '1.20.4', '1.20.6', '1.21.1']
|
supportedVersions: ['1.7', '1.8.8', '1.9.4', '1.10.2', '1.11.2', '1.12.2', '1.13.2', '1.14.4', '1.15.2', '1.16.5', '1.17.1', '1.18.2', '1.19', '1.19.2', '1.19.3', '1.19.4', '1.20', '1.20.1', '1.20.2', '1.20.4', '1.20.6', '1.21.1', '1.21.3']
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue