mirror of
https://github.com/pmmp/PocketMine-MP.git
synced 2025-09-07 02:08:21 +00:00
New generic in-memory chunk format, fixed 0.17.0.1 chunk loading
Terrible performance, needs profiling. TODO: fix this.
This commit is contained in:
@ -21,7 +21,8 @@
|
||||
|
||||
namespace pocketmine\level\generator;
|
||||
|
||||
use pocketmine\level\format\FullChunk;
|
||||
use pocketmine\level\format\Chunk;
|
||||
use pocketmine\level\format\generic\GenericChunk;
|
||||
use pocketmine\level\Level;
|
||||
use pocketmine\level\SimpleChunkManager;
|
||||
use pocketmine\scheduler\AsyncTask;
|
||||
@ -34,10 +35,10 @@ class GenerationTask extends AsyncTask{
|
||||
public $chunk;
|
||||
public $chunkClass;
|
||||
|
||||
public function __construct(Level $level, FullChunk $chunk){
|
||||
public function __construct(Level $level, Chunk $chunk){
|
||||
$this->state = true;
|
||||
$this->levelId = $level->getId();
|
||||
$this->chunk = $chunk->toFastBinary();
|
||||
$this->chunk = GenericChunk::fastSerialize($chunk);
|
||||
$this->chunkClass = get_class($chunk);
|
||||
}
|
||||
|
||||
@ -51,9 +52,9 @@ class GenerationTask extends AsyncTask{
|
||||
return;
|
||||
}
|
||||
|
||||
/** @var FullChunk $chunk */
|
||||
/** @var Chunk $chunk */
|
||||
$chunk = $this->chunkClass;
|
||||
$chunk = $chunk::fromFastBinary($this->chunk);
|
||||
$chunk = GenericChunk::fastDeserialize($this->chunk);
|
||||
if($chunk === null){
|
||||
//TODO error
|
||||
return;
|
||||
@ -65,7 +66,7 @@ class GenerationTask extends AsyncTask{
|
||||
|
||||
$chunk = $manager->getChunk($chunk->getX(), $chunk->getZ());
|
||||
$chunk->setGenerated();
|
||||
$this->chunk = $chunk->toFastBinary();
|
||||
$this->chunk = GenericChunk::fastSerialize($chunk);
|
||||
|
||||
$manager->setChunk($chunk->getX(), $chunk->getZ(), null);
|
||||
}
|
||||
@ -77,9 +78,9 @@ class GenerationTask extends AsyncTask{
|
||||
$level->registerGenerator();
|
||||
return;
|
||||
}
|
||||
/** @var FullChunk $chunk */
|
||||
/** @var Chunk $chunk */
|
||||
$chunk = $this->chunkClass;
|
||||
$chunk = $chunk::fromFastBinary($this->chunk, $level->getProvider());
|
||||
$chunk = GenericChunk::fastDeserialize($this->chunk, $level->getProvider());
|
||||
if($chunk === null){
|
||||
//TODO error
|
||||
return;
|
||||
|
Reference in New Issue
Block a user