{
  "craftItem": "The `craftItem` function is an asynchronous skill designed for a Minecraft bot, enabling it to craft a specified item a given number of times. The function first validates the input parameters, ensuring that the item name is a string and the count is a number. It retrieves the item data using the provided name and searches for a nearby crafting table within a 32-block radius. If a crafting table is found, the bot navigates to it; otherwise, it proceeds without one. The function then identifies the appropriate crafting recipe for the item. If a recipe is found, the bot attempts to craft the item the specified number of times, providing feedback through chat messages. If crafting fails, the bot provides failure feedback and increments a fail counter, throwing an error if the failure count exceeds ten attempts.",
  "exploreUntil": "The `exploreUntil` function is an asynchronous skill for a Minecraft bot, enabling it to explore in a specified direction (represented by a Vec3 object) for a maximum duration, defaulting to 60 seconds. The function validates the input parameters, ensuring the direction is valid and the maximum time is a number. It uses a callback function to determine if the exploration criteria have been met. The bot navigates in the given direction at random intervals, setting a pathfinder goal within a specified range. If the callback condition is met during exploration, the function cleans up and resolves successfully. If the maximum exploration time is reached, it stops exploring and resolves with null. The bot provides feedback through chat messages for both success and timeout scenarios.",
  "givePlacedItemBack": "The `givePlacedItemBack` function is an asynchronous skill for a Minecraft bot that retrieves specified items from given positions by manipulating game rules and block states. Initially, the function disables tile drops to prevent item duplication, then iterates through the provided item names and their corresponding positions. For each item, it calls a helper function, `givePlacedItemBackSingle`, which first gives the bot one of the specified items. The bot then searches within a 3x3x3 cube around the target position for a matching block. If found, the block is destroyed and removed from the game, effectively giving back the item. The function ensures no duplicate actions by keeping a history of processed block positions. After processing all items, tile drops are re-enabled, and the bot provides feedback through chat messages.",
  "killMob": "The `killMob` function is an asynchronous skill for a Minecraft bot that enables it to locate and eliminate a specified type of mob within a given timeout period, defaulting to 300 seconds. The function begins by validating the input parameters, ensuring that the mob name is a string and the timeout is a number. It then checks the bot's inventory for ranged weapons such as a bow or crossbow. The bot identifies the nearest mob matching the specified name within a 48-block radius. If no such mob is found, the function increments a failure count and advises exploration if repeated failures occur. Upon finding the target mob, the bot uses an appropriate weapon to attack, either through ranged auto-attacks or direct melee attacks. After successfully killing the mob, the bot collects any dropped items. If the process is successful, it saves a record indicating the mob has been killed.",
  "mineBlock": "The `mineBlock` function is an asynchronous skill for a Minecraft bot that allows it to mine a specified type of block a given number of times, defaulting to one. The function begins by validating the input parameters to ensure that the block name is a string and the count is a number. It retrieves the block data using the provided name and searches for matching blocks within a 32-block radius. If no blocks are found, the bot suggests exploring first and increments a failure count, throwing an error if the failure count exceeds ten attempts. Upon finding the target blocks, the bot collects them, ensuring it reaches the specified count. Once the blocks are successfully mined, the bot saves a record indicating the block has been mined.",
  "placeItem": "The `placeItem` function is an asynchronous skill for a Minecraft bot that places a specified item at a given position. The function begins by validating the input parameters to ensure the item name is a string and the position is a Vec3 object. It retrieves the item data using the provided name and checks the bot's inventory for the item. If the item is not found, the bot notifies the user and exits. The function then searches for a suitable reference block adjacent to the target position to place the item, as items cannot be placed in mid-air. If no suitable reference block is found, the bot increments a failure count and suggests finding a different position. Once a reference block is identified, the bot navigates to the target position, equips the item, and attempts to place it. If successful, it saves a record of the placement. If an error occurs, the bot checks if the item count has changed to confirm placement, otherwise, it increments a failure count and advises trying a different position.",
  "shoot": "The `shoot` function is an asynchronous skill for a Minecraft bot that enables it to use a specified ranged weapon to attack a target mob. The function first validates the provided weapon against a list of acceptable weapons such as a bow, crossbow, or trident. It checks the bot's inventory for the specified weapon and if it is not found, the bot notifies the user and exits. The function then identifies the nearest entity matching the target name. If no such target is found, the bot notifies the user and exits. Upon finding the target, the bot uses the `hawkEye.autoAttack` method to automatically aim and shoot at the target with the specified weapon. The function is designed to handle the shooting process efficiently, ensuring that the bot only attempts to shoot if all conditions are met.",
  "smeltItem": "The `smeltItem` function is an asynchronous skill for a Minecraft bot that allows it to smelt a specified item using a specified fuel a given number of times, defaulting to one. The function validates the input parameters to ensure both the item name and fuel name are strings and the count is a number. It retrieves the item and fuel data from the game and checks if they exist. The bot then searches for a nearby furnace within a 32-block radius and navigates to it. Once at the furnace, the bot opens it and begins the smelting process. It iterates through the specified count, checking if the item and fuel are available in the inventory. If the furnace's fuel is insufficient, the bot adds the specified fuel. The bot places the item in the furnace, waits for it to smelt, and then retrieves the output. The function keeps track of successful smelts and provides feedback through chat messages. If any issues occur, such as insufficient fuel or invalid input, the bot notifies the user and increments a failure count, potentially throwing an error after multiple failures."
}