Skip to content

Commit

Permalink
Merge branch 'PrismarineJS:master' into master
Browse files Browse the repository at this point in the history
  • Loading branch information
zardoy authored Oct 28, 2024
2 parents f5fb0bc + 3d6e234 commit 519acba
Show file tree
Hide file tree
Showing 9 changed files with 37 additions and 19 deletions.
3 changes: 2 additions & 1 deletion docs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ First time using Node.js? You may want to start with the [tutorial](tutorial.md)

## Features

* Supports Minecraft 1.8 to 1.20.5 (1.8, 1.9, 1.10, 1.11, 1.12, 1.13, 1.14, 1.15, 1.16, 1.17, 1.18, 1.19 and 1.20 upto 1.20.6)
* Supports Minecraft 1.8 to 1.21 (1.8, 1.9, 1.10, 1.11, 1.12, 1.13, 1.14, 1.15, 1.16, 1.17, 1.18, 1.19, 1.20, and 1.21)
* Entity knowledge and tracking.
* Block knowledge. You can query the world around you. Milliseconds to find any block.
* Physics and movement - handle all bounding boxes
Expand Down Expand Up @@ -234,6 +234,7 @@ The most updated and useful are :
## Projects Using Mineflayer

* [Voyager](https://github.com/MineDojo/Voyager) An Open-Ended Embodied Agent with Large Language Models
* [mindcraft](https://github.com/kolbytn/mindcraft) Lib for using mineflayer with LLMs
* [rom1504/rbot](https://github.com/rom1504/rbot)
- [YouTube - building a spiral staircase](https://www.youtube.com/watch?v=UM1ZV5200S0)
- [YouTube - replicating a building](https://www.youtube.com/watch?v=0cQxg9uDnzA)
Expand Down
4 changes: 4 additions & 0 deletions docs/history.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
## 4.23.0
* [1.21 (#3480)](https://github.com/PrismarineJS/mineflayer/commit/4aa10fb45431940504c7809f078f1f410e7fa7a3) (thanks @Madlykeanu)
* [Adding mindcraft to mineflayer readme](https://github.com/PrismarineJS/mineflayer/commit/dd00db42ba20682418d8fbd5629e1033dfb0ff20) (thanks @rom1504)

## 4.22.0
* [Remove debug logging (#3478)](https://github.com/PrismarineJS/mineflayer/commit/eb29d350ede0590fce17e04bf21071807a87e3a1) (thanks @extremeheat)

Expand Down
5 changes: 3 additions & 2 deletions lib/plugins/chat.js
Original file line number Diff line number Diff line change
Expand Up @@ -118,10 +118,11 @@ function inject (bot, options) {
target: data.targetName ? JSON.parse(data.targetName) : undefined,
content: message ? JSON.parse(message) : { text: data.plainMessage }
}
msg = ChatMessage.fromNetwork(data.type, parameters)
const registryIndex = data.type.registryIndex ? data.type.registryIndex : data.type
msg = ChatMessage.fromNetwork(registryIndex, parameters)

if (data.unsignedContent) {
msg.unsigned = ChatMessage.fromNetwork(data.type, { sender: parameters.sender, target: parameters.target, content: JSON.parse(data.unsignedContent) })
msg.unsigned = ChatMessage.fromNetwork(registryIndex, { sender: parameters.sender, target: parameters.target, content: JSON.parse(data.unsignedContent) })
}
} else {
msg = ChatMessage.fromNotch(message)
Expand Down
3 changes: 2 additions & 1 deletion lib/plugins/inventory.js
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,8 @@ function inject (bot, { hideErrors }) {
})
} else if (bot.supportFeature('useItemWithOwnPacket')) {
bot._client.write('use_item', {
hand: offHand ? 1 : 0
hand: offHand ? 1 : 0,
rotation: { x: 0, y: 0 }
})
}
}
Expand Down
2 changes: 1 addition & 1 deletion lib/version.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const testedVersions = ['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', '1.20.2', '1.20.4', '1.20.6']
const testedVersions = ['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', '1.20.2', '1.20.4', '1.20.6', '1.21.1']
module.exports = {

testedVersions,
Expand Down
12 changes: 6 additions & 6 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "mineflayer",
"version": "4.22.0",
"version": "4.23.0",
"description": "create minecraft bots with a stable, high level API",
"main": "index.js",
"types": "index.d.ts",
Expand All @@ -22,17 +22,17 @@
"license": "MIT",
"dependencies": {
"minecraft-data": "^3.76.0",
"minecraft-protocol": "^1.49.0",
"minecraft-protocol": "^1.50.0",
"prismarine-biome": "^1.1.1",
"prismarine-block": "^1.17.0",
"prismarine-chat": "^1.7.1",
"prismarine-chunk": "^1.34.0",
"prismarine-chunk": "^1.36.0",
"prismarine-entity": "^2.3.0",
"prismarine-item": "^1.15.0",
"prismarine-nbt": "^2.0.0",
"prismarine-physics": "^1.8.0",
"prismarine-physics": "^1.9.0",
"prismarine-recipe": "^1.3.0",
"prismarine-registry": "^1.8.0",
"prismarine-registry": "^1.10.0",
"prismarine-windows": "^2.9.0",
"prismarine-world": "^3.6.0",
"protodef": "1.17.0",
Expand All @@ -43,7 +43,7 @@
"@types/node": "^22.1.0",
"doctoc": "^2.0.1",
"minecraft-wrap": "^1.3.0",
"mineflayer": "file:.",
"mineflayer": "file:",
"mocha": "^10.0.0",
"protodef-yaml": "^1.5.3",
"standard": "^17.0.0",
Expand Down
2 changes: 1 addition & 1 deletion test/externalTests/fishing.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
module.exports = () => async (bot) => {
const Item = require('prismarine-item')(bot.registry)

bot.test.sayEverywhere('/fill ~-5 ~-1 ~-5 ~5 ~-1 ~5 water')
bot.test.sayEverywhere('/fill ~-10 ~-1 ~-10 ~10 ~-1 ~10 water')
await bot.test.setInventorySlot(36, new Item(bot.registry.itemsByName.fishing_rod.id, 1, 0))
await bot.lookAt(bot.entity.position) // dont force the position
bot.fish()
Expand Down
2 changes: 1 addition & 1 deletion test/externalTests/plugins/testCommon.js
Original file line number Diff line number Diff line change
Expand Up @@ -225,7 +225,7 @@ function inject (bot) {
}

try {
await withTimeout(Promise.all([detectChildJoin(), runExampleOnReady()]), 20000)
await withTimeout(Promise.all([detectChildJoin(), runExampleOnReady()]), 30000)
} catch (err) {
console.log(err)
return closeExample(err)
Expand Down
23 changes: 17 additions & 6 deletions test/internalTest.js
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,6 @@ for (const supportedVersion of mineflayer.testedVersions) {
// 25565 - local server, 25566 - proxy server
port: 25567
})
console.log('Server Codec', server.registryCodec)
server.on('listening', () => {
bot = mineflayer.createBot({
username: 'player',
Expand Down Expand Up @@ -130,7 +129,19 @@ for (const supportedVersion of mineflayer.testedVersions) {
const uuid = 'd3527a0b-bc03-45d5-a878-2aafdd8c8a43' // random
const networkName = chatText('gary')

if (registry.supportFeature('useChatSessions')) {
if (registry.supportFeature('incrementedChatType')) {
client.write('player_chat', {
plainMessage: 'hello',
filterType: 0,
type: { registryIndex: 1 },
networkName,
previousMessages: [],
senderUuid: uuid,
timestamp: Date.now(),
index: 0,
salt: 0n
})
} else if (registry.supportFeature('useChatSessions')) {
client.write('player_chat', {
plainMessage: 'hello',
filterType: 0,
Expand Down Expand Up @@ -909,9 +920,9 @@ for (const supportedVersion of mineflayer.testedVersions) {

const zombieId = entities.zombie ? entities.zombie.id : entities.Zombie.id
let bedBlock
if (mineflayer.supportFeature('oneBlockForSeveralVariations', version.majorVersion)) {
if (bot.supportFeature('oneBlockForSeveralVariations', version.majorVersion)) {
bedBlock = blocks.bed
} else if (mineflayer.supportFeature('blockSchemeIsFlat', version.majorVersion)) {
} else if (bot.supportFeature('blockSchemeIsFlat', version.majorVersion)) {
bedBlock = blocks.red_bed
}
const bedId = bedBlock.id
Expand Down Expand Up @@ -945,7 +956,7 @@ for (const supportedVersion of mineflayer.testedVersions) {
chunk.setBlockType(beds[bed].foot, bedId)
}

if (mineflayer.supportFeature('blockStateId', version.majorVersion)) {
if (bot.supportFeature('blockStateId', version.majorVersion)) {
chunk.setBlockStateId(beds[0].foot, 3 + bedBlock.minStateId) // { facing: north, occupied: false, part: foot }
chunk.setBlockStateId(beds[0].head, 2 + bedBlock.minStateId) // { facing:north, occupied: false, part: head }

Expand All @@ -957,7 +968,7 @@ for (const supportedVersion of mineflayer.testedVersions) {

chunk.setBlockStateId(beds[3].foot, 11 + bedBlock.minStateId) // { facing: west, occupied: false, part: foot }
chunk.setBlockStateId(beds[3].head, 10 + bedBlock.minStateId) // { facing: west, occupied: false, part: head }
} else if (mineflayer.supportFeature('blockMetadata', version.majorVersion)) {
} else if (bot.supportFeature('blockMetadata', version.majorVersion)) {
chunk.setBlockData(beds[0].foot, 2) // { facing: north, occupied: false, part: foot }
chunk.setBlockData(beds[0].head, 10) // { facing:north, occupied: false, part: head }

Expand Down

0 comments on commit 519acba

Please sign in to comment.