mirror of
https://github.com/pmmp/PocketMine-MP.git
synced 2025-04-20 16:00:20 +00:00
BlockStateDictionary: extract a more generic helper method for decoding block palette files
This commit is contained in:
parent
dc8f65c0dd
commit
a8728a02f6
@ -29,11 +29,9 @@ use pocketmine\data\bedrock\block\BlockStateStringValues;
|
||||
use pocketmine\data\bedrock\block\BlockTypeNames;
|
||||
use pocketmine\errorhandler\ErrorToExceptionHandler;
|
||||
use pocketmine\nbt\NbtException;
|
||||
use pocketmine\nbt\TreeRoot;
|
||||
use pocketmine\network\mcpe\protocol\serializer\NetworkNbtSerializer;
|
||||
use pocketmine\network\mcpe\convert\BlockStateDictionary;
|
||||
use pocketmine\utils\AssumptionFailedError;
|
||||
use pocketmine\utils\Utils;
|
||||
use function array_map;
|
||||
use function array_values;
|
||||
use function asort;
|
||||
use function count;
|
||||
@ -183,10 +181,7 @@ if($paletteRaw === false){
|
||||
}
|
||||
|
||||
try{
|
||||
$states = array_map(
|
||||
fn(TreeRoot $root) => BlockStateData::fromNbt($root->mustGetCompoundTag()),
|
||||
(new NetworkNbtSerializer())->readMultiple($paletteRaw)
|
||||
);
|
||||
$states = BlockStateDictionary::loadPaletteFromString($paletteRaw);
|
||||
}catch(NbtException){
|
||||
fwrite(STDERR, "Invalid block palette file $argv[1]\n");
|
||||
exit(1);
|
||||
|
@ -24,6 +24,7 @@ declare(strict_types=1);
|
||||
namespace pocketmine\network\mcpe\convert;
|
||||
|
||||
use pocketmine\data\bedrock\block\BlockStateData;
|
||||
use pocketmine\nbt\NbtDataException;
|
||||
use pocketmine\nbt\TreeRoot;
|
||||
use pocketmine\network\mcpe\protocol\serializer\NetworkNbtSerializer;
|
||||
use function array_map;
|
||||
@ -107,6 +108,19 @@ final class BlockStateDictionary{
|
||||
*/
|
||||
public function getStates() : array{ return $this->states; }
|
||||
|
||||
/**
|
||||
* @return BlockStateData[]
|
||||
* @phpstan-return list<BlockStateData>
|
||||
*
|
||||
* @throws NbtDataException
|
||||
*/
|
||||
public static function loadPaletteFromString(string $blockPaletteContents) : array{
|
||||
return array_map(
|
||||
fn(TreeRoot $root) => BlockStateData::fromNbt($root->mustGetCompoundTag()),
|
||||
(new NetworkNbtSerializer())->readMultiple($blockPaletteContents)
|
||||
);
|
||||
}
|
||||
|
||||
public static function loadFromString(string $blockPaletteContents, string $metaMapContents) : self{
|
||||
$metaMap = json_decode($metaMapContents, flags: JSON_THROW_ON_ERROR);
|
||||
if(!is_array($metaMap)){
|
||||
@ -114,12 +128,8 @@ final class BlockStateDictionary{
|
||||
}
|
||||
|
||||
$entries = [];
|
||||
$states = array_map(
|
||||
fn(TreeRoot $root) => BlockStateData::fromNbt($root->mustGetCompoundTag()),
|
||||
(new NetworkNbtSerializer())->readMultiple($blockPaletteContents)
|
||||
);
|
||||
|
||||
foreach($states as $i => $state){
|
||||
foreach(self::loadPaletteFromString($blockPaletteContents) as $i => $state){
|
||||
$meta = $metaMap[$i] ?? null;
|
||||
if($meta === null){
|
||||
throw new \InvalidArgumentException("Missing associated meta value for state $i (" . $state->toNbt() . ")");
|
||||
|
@ -23,17 +23,14 @@ declare(strict_types=1);
|
||||
|
||||
namespace pocketmine\tools\generate_block_palette_spec;
|
||||
|
||||
use pocketmine\data\bedrock\block\BlockStateData;
|
||||
use pocketmine\errorhandler\ErrorToExceptionHandler;
|
||||
use pocketmine\nbt\NbtException;
|
||||
use pocketmine\nbt\tag\ByteTag;
|
||||
use pocketmine\nbt\tag\IntTag;
|
||||
use pocketmine\nbt\tag\StringTag;
|
||||
use pocketmine\nbt\TreeRoot;
|
||||
use pocketmine\network\mcpe\protocol\serializer\NetworkNbtSerializer;
|
||||
use pocketmine\network\mcpe\convert\BlockStateDictionary;
|
||||
use pocketmine\utils\AssumptionFailedError;
|
||||
use pocketmine\utils\Utils;
|
||||
use function array_map;
|
||||
use function array_values;
|
||||
use function count;
|
||||
use function dirname;
|
||||
@ -54,10 +51,7 @@ if(count($argv) !== 3){
|
||||
[, $inputFile, $outputFile] = $argv;
|
||||
|
||||
try{
|
||||
$states = array_map(
|
||||
fn(TreeRoot $root) => BlockStateData::fromNbt($root->mustGetCompoundTag()),
|
||||
(new NetworkNbtSerializer())->readMultiple(ErrorToExceptionHandler::trapAndRemoveFalse(fn() => file_get_contents($inputFile)))
|
||||
);
|
||||
$states = BlockStateDictionary::loadPaletteFromString(ErrorToExceptionHandler::trapAndRemoveFalse(fn() => file_get_contents($inputFile)));
|
||||
}catch(NbtException){
|
||||
fwrite(STDERR, "Invalid block palette file $argv[1]\n");
|
||||
exit(1);
|
||||
|
Loading…
x
Reference in New Issue
Block a user