mirror of
https://github.com/pmmp/PocketMine-MP.git
synced 2025-06-07 20:28:31 +00:00
Refactor GenericChunk::fastSerialize() to be non-static, fix some unbelievable bugs, clean up some leftovers
This commit is contained in:
parent
598e7aac8f
commit
d8908676ac
@ -363,13 +363,11 @@ interface Chunk{
|
|||||||
public function networkSerialize() : string;
|
public function networkSerialize() : string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Serializes a chunk without compression for use in AsyncTasks.
|
* Serializes the chunk without compression for use in AsyncTasks.
|
||||||
*
|
|
||||||
* @param Chunk $chunk
|
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function fastSerialize(Chunk $chunk) : string;
|
public function fastSerialize() : string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deserializes a chunk from fast serialization
|
* Deserializes a chunk from fast serialization
|
||||||
|
@ -21,6 +21,7 @@
|
|||||||
|
|
||||||
namespace pocketmine\level\format\generic;
|
namespace pocketmine\level\format\generic;
|
||||||
|
|
||||||
|
use pocketmine\level\format\Chunk;
|
||||||
use pocketmine\level\Level;
|
use pocketmine\level\Level;
|
||||||
use pocketmine\nbt\NBT;
|
use pocketmine\nbt\NBT;
|
||||||
use pocketmine\scheduler\AsyncTask;
|
use pocketmine\scheduler\AsyncTask;
|
||||||
@ -40,7 +41,7 @@ class ChunkRequestTask extends AsyncTask{
|
|||||||
public function __construct(Level $level, Chunk $chunk){
|
public function __construct(Level $level, Chunk $chunk){
|
||||||
$this->levelId = $level->getId();
|
$this->levelId = $level->getId();
|
||||||
|
|
||||||
$this->chunk = GenericChunk::fastSerialize($chunk);
|
$this->chunk = $chunk->fastSerialize();
|
||||||
$this->chunkX = $chunk->getX();
|
$this->chunkX = $chunk->getX();
|
||||||
$this->chunkZ = $chunk->getZ();
|
$this->chunkZ = $chunk->getZ();
|
||||||
|
|
||||||
|
@ -621,13 +621,13 @@ class GenericChunk implements Chunk{
|
|||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function fastSerialize(Chunk $chunk) : string{
|
public function fastSerialize() : string{
|
||||||
$stream = new BinaryStream();
|
$stream = new BinaryStream();
|
||||||
$stream->putInt($chunk->x);
|
$stream->putInt($this->x);
|
||||||
$stream->putInt($chunk->z);
|
$stream->putInt($this->z);
|
||||||
$count = 0;
|
$count = 0;
|
||||||
$subChunks = "";
|
$subChunks = "";
|
||||||
foreach($chunk->subChunks as $y => $subChunk){
|
foreach($this->subChunks as $y => $subChunk){
|
||||||
if($subChunk instanceof EmptySubChunk){
|
if($subChunk instanceof EmptySubChunk){
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -636,9 +636,9 @@ class GenericChunk implements Chunk{
|
|||||||
}
|
}
|
||||||
$stream->putByte($count);
|
$stream->putByte($count);
|
||||||
$stream->put($subChunks);
|
$stream->put($subChunks);
|
||||||
$stream->put(pack("C*", ...$chunk->getHeightMapArray()) .
|
$stream->put(pack("C*", ...$this->heightMap) .
|
||||||
$chunk->getBiomeIdArray() .
|
$this->biomeIds .
|
||||||
chr(($chunk->lightPopulated ? 1 << 2 : 0) | ($chunk->terrainPopulated ? 1 << 1 : 0) | ($chunk->terrainGenerated ? 1 : 0)));
|
chr(($this->lightPopulated ? 1 << 2 : 0) | ($this->terrainPopulated ? 1 << 1 : 0) | ($this->terrainGenerated ? 1 : 0)));
|
||||||
//TODO: tiles and entities
|
//TODO: tiles and entities
|
||||||
return $stream->getBuffer();
|
return $stream->getBuffer();
|
||||||
}
|
}
|
||||||
|
@ -33,13 +33,11 @@ class GenerationTask extends AsyncTask{
|
|||||||
public $state;
|
public $state;
|
||||||
public $levelId;
|
public $levelId;
|
||||||
public $chunk;
|
public $chunk;
|
||||||
public $chunkClass;
|
|
||||||
|
|
||||||
public function __construct(Level $level, Chunk $chunk){
|
public function __construct(Level $level, Chunk $chunk){
|
||||||
$this->state = true;
|
$this->state = true;
|
||||||
$this->levelId = $level->getId();
|
$this->levelId = $level->getId();
|
||||||
$this->chunk = GenericChunk::fastSerialize($chunk);
|
$this->chunk = $chunk->fastSerialize();
|
||||||
$this->chunkClass = get_class($chunk);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function onRun(){
|
public function onRun(){
|
||||||
@ -65,7 +63,7 @@ class GenerationTask extends AsyncTask{
|
|||||||
|
|
||||||
$chunk = $manager->getChunk($chunk->getX(), $chunk->getZ());
|
$chunk = $manager->getChunk($chunk->getX(), $chunk->getZ());
|
||||||
$chunk->setGenerated();
|
$chunk->setGenerated();
|
||||||
$this->chunk = GenericChunk::fastSerialize($chunk);
|
$this->chunk = $chunk->fastSerialize();
|
||||||
|
|
||||||
$manager->setChunk($chunk->getX(), $chunk->getZ(), null);
|
$manager->setChunk($chunk->getX(), $chunk->getZ(), null);
|
||||||
}
|
}
|
||||||
|
@ -31,12 +31,10 @@ class LightPopulationTask extends AsyncTask{
|
|||||||
|
|
||||||
public $levelId;
|
public $levelId;
|
||||||
public $chunk;
|
public $chunk;
|
||||||
public $chunkClass;
|
|
||||||
|
|
||||||
public function __construct(Level $level, Chunk $chunk){
|
public function __construct(Level $level, Chunk $chunk){
|
||||||
$this->levelId = $level->getId();
|
$this->levelId = $level->getId();
|
||||||
$this->chunk = GenericChunk::fastDeserialize($this->chunk);
|
$this->chunk = $chunk->fastSerialize();
|
||||||
$this->chunkClass = get_class($chunk);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function onRun(){
|
public function onRun(){
|
||||||
@ -51,7 +49,7 @@ class LightPopulationTask extends AsyncTask{
|
|||||||
$chunk->populateSkyLight();
|
$chunk->populateSkyLight();
|
||||||
$chunk->setLightPopulated();
|
$chunk->setLightPopulated();
|
||||||
|
|
||||||
$this->chunk = GenericChunk::fastSerialize($chunk);
|
$this->chunk = $chunk->fastSerialize();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function onCompletion(Server $server){
|
public function onCompletion(Server $server){
|
||||||
|
@ -47,7 +47,7 @@ class PopulationTask extends AsyncTask{
|
|||||||
public function __construct(Level $level, Chunk $chunk){
|
public function __construct(Level $level, Chunk $chunk){
|
||||||
$this->state = true;
|
$this->state = true;
|
||||||
$this->levelId = $level->getId();
|
$this->levelId = $level->getId();
|
||||||
$this->chunk = GenericChunk::fastSerialize($chunk);
|
$this->chunk = $chunk->fastSerialize();
|
||||||
|
|
||||||
for($i = 0; $i < 9; ++$i){
|
for($i = 0; $i < 9; ++$i){
|
||||||
if($i === 4){
|
if($i === 4){
|
||||||
@ -56,7 +56,7 @@ class PopulationTask extends AsyncTask{
|
|||||||
$xx = -1 + $i % 3;
|
$xx = -1 + $i % 3;
|
||||||
$zz = -1 + (int) ($i / 3);
|
$zz = -1 + (int) ($i / 3);
|
||||||
$ck = $level->getChunk($chunk->getX() + $xx, $chunk->getZ() + $zz, false);
|
$ck = $level->getChunk($chunk->getX() + $xx, $chunk->getZ() + $zz, false);
|
||||||
$this->{"chunk$i"} = $ck !== null ? GenericChunk::fastSerialize($ck) : null;
|
$this->{"chunk$i"} = $ck !== null ? $ck->fastSerialize() : null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -118,7 +118,7 @@ class PopulationTask extends AsyncTask{
|
|||||||
$chunk->populateSkyLight();
|
$chunk->populateSkyLight();
|
||||||
$chunk->setLightPopulated();
|
$chunk->setLightPopulated();
|
||||||
$chunk->setPopulated();
|
$chunk->setPopulated();
|
||||||
$this->chunk = GenericChunk::fastSerialize($chunk);
|
$this->chunk = $chunk->fastSerialize();
|
||||||
|
|
||||||
$manager->setChunk($chunk->getX(), $chunk->getZ(), null);
|
$manager->setChunk($chunk->getX(), $chunk->getZ(), null);
|
||||||
|
|
||||||
@ -141,7 +141,7 @@ class PopulationTask extends AsyncTask{
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->{"chunk$i"} = $chunks[$i] !== null ? GenericChunk::fastSerialize($chunks[$i]) : null;
|
$this->{"chunk$i"} = $chunks[$i] !== null ? $chunks[$i]->fastSerialize() : null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user