Refactor GenericChunk::fastSerialize() to be non-static, fix some unbelievable bugs, clean up some leftovers

This commit is contained in:
Dylan K. Taylor 2017-01-04 21:13:42 +00:00
parent 598e7aac8f
commit d8908676ac
6 changed files with 19 additions and 24 deletions

View File

@ -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

View File

@ -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();

View File

@ -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();
} }

View File

@ -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);
} }

View File

@ -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){

View File

@ -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;
} }
} }