mirror of
https://github.com/pmmp/PocketMine-MP.git
synced 2025-09-06 09:56:06 +00:00
Improved world generation manager, UUIDs (some work for future usage)
This commit is contained in:
@ -32,17 +32,13 @@ use pocketmine\utils\Random;
|
||||
|
||||
class GenerationTask extends AsyncTask{
|
||||
|
||||
public $generator;
|
||||
public $settings;
|
||||
public $seed;
|
||||
public $state;
|
||||
public $levelId;
|
||||
public $chunk;
|
||||
public $chunkClass;
|
||||
|
||||
public function __construct(Level $level, Generator $generator, FullChunk $chunk){
|
||||
$this->generator = get_class($generator);
|
||||
$this->settings = $generator->getSettings();
|
||||
$this->seed = $level->getSeed();
|
||||
public function __construct(Level $level, FullChunk $chunk){
|
||||
$this->state = true;
|
||||
$this->levelId = $level->getId();
|
||||
$this->chunk = $chunk->toFastBinary();
|
||||
$this->chunkClass = get_class($chunk);
|
||||
@ -50,19 +46,12 @@ class GenerationTask extends AsyncTask{
|
||||
|
||||
public function onRun(){
|
||||
/** @var SimpleChunkManager $manager */
|
||||
$manager = $this->getFromThreadStore($key = "generation.level{$this->levelId}.manager");
|
||||
$manager = $this->getFromThreadStore("generation.level{$this->levelId}.manager");
|
||||
/** @var Generator $generator */
|
||||
$generator = $this->getFromThreadStore($gKey = "generation.level{$this->levelId}.generator");
|
||||
$generator = $this->getFromThreadStore("generation.level{$this->levelId}.generator");
|
||||
if($manager === null or $generator === null){
|
||||
Block::init();
|
||||
Biome::init();
|
||||
$manager = new SimpleChunkManager($this->seed);
|
||||
$this->saveToThreadStore($key, $manager);
|
||||
/** @var Generator $generator */
|
||||
$generator = $this->generator;
|
||||
$generator = new $generator($this->settings);
|
||||
$generator->init($manager, new Random($manager->getSeed()));
|
||||
$this->saveToThreadStore($gKey, $generator);
|
||||
$this->state = false;
|
||||
return;
|
||||
}
|
||||
|
||||
/** @var FullChunk $chunk */
|
||||
@ -87,6 +76,10 @@ class GenerationTask extends AsyncTask{
|
||||
public function onCompletion(Server $server){
|
||||
$level = $server->getLevel($this->levelId);
|
||||
if($level !== null){
|
||||
if($this->state === false){
|
||||
$level->registerGenerator();
|
||||
return;
|
||||
}
|
||||
/** @var FullChunk $chunk */
|
||||
$chunk = $this->chunkClass;
|
||||
$chunk = $chunk::fromFastBinary($this->chunk, $level->getProvider());
|
||||
|
58
src/pocketmine/level/generator/GeneratorRegisterTask.php
Normal file
58
src/pocketmine/level/generator/GeneratorRegisterTask.php
Normal file
@ -0,0 +1,58 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
*
|
||||
* ____ _ _ __ __ _ __ __ ____
|
||||
* | _ \ ___ ___| | _____| |_| \/ (_)_ __ ___ | \/ | _ \
|
||||
* | |_) / _ \ / __| |/ / _ \ __| |\/| | | '_ \ / _ \_____| |\/| | |_) |
|
||||
* | __/ (_) | (__| < __/ |_| | | | | | | | __/_____| | | | __/
|
||||
* |_| \___/ \___|_|\_\___|\__|_| |_|_|_| |_|\___| |_| |_|_|
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Lesser General Public License as published by
|
||||
* the Free Software Foundation, either version 3 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* @author PocketMine Team
|
||||
* @link http://www.pocketmine.net/
|
||||
*
|
||||
*
|
||||
*/
|
||||
|
||||
namespace pocketmine\level\generator;
|
||||
|
||||
use pocketmine\block\Block;
|
||||
use pocketmine\level\format\FullChunk;
|
||||
use pocketmine\level\generator\biome\Biome;
|
||||
use pocketmine\level\Level;
|
||||
use pocketmine\level\SimpleChunkManager;
|
||||
use pocketmine\scheduler\AsyncTask;
|
||||
use pocketmine\Server;
|
||||
use pocketmine\utils\Random;
|
||||
|
||||
class GeneratorRegisterTask extends AsyncTask{
|
||||
|
||||
public $generator;
|
||||
public $settings;
|
||||
public $seed;
|
||||
public $levelId;
|
||||
|
||||
public function __construct(Level $level, Generator $generator){
|
||||
$this->generator = get_class($generator);
|
||||
$this->settings = $generator->getSettings();
|
||||
$this->seed = $level->getSeed();
|
||||
$this->levelId = $level->getId();
|
||||
}
|
||||
|
||||
public function onRun(){
|
||||
Block::init();
|
||||
Biome::init();
|
||||
$manager = new SimpleChunkManager($this->seed);
|
||||
$this->saveToThreadStore("generation.level{$this->levelId}.manager", $manager);
|
||||
/** @var Generator $generator */
|
||||
$generator = $this->generator;
|
||||
$generator = new $generator($this->settings);
|
||||
$generator->init($manager, new Random($manager->getSeed()));
|
||||
$this->saveToThreadStore("generation.level{$this->levelId}.generator", $generator);
|
||||
}
|
||||
}
|
45
src/pocketmine/level/generator/GeneratorUnregisterTask.php
Normal file
45
src/pocketmine/level/generator/GeneratorUnregisterTask.php
Normal file
@ -0,0 +1,45 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
*
|
||||
* ____ _ _ __ __ _ __ __ ____
|
||||
* | _ \ ___ ___| | _____| |_| \/ (_)_ __ ___ | \/ | _ \
|
||||
* | |_) / _ \ / __| |/ / _ \ __| |\/| | | '_ \ / _ \_____| |\/| | |_) |
|
||||
* | __/ (_) | (__| < __/ |_| | | | | | | | __/_____| | | | __/
|
||||
* |_| \___/ \___|_|\_\___|\__|_| |_|_|_| |_|\___| |_| |_|_|
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Lesser General Public License as published by
|
||||
* the Free Software Foundation, either version 3 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* @author PocketMine Team
|
||||
* @link http://www.pocketmine.net/
|
||||
*
|
||||
*
|
||||
*/
|
||||
|
||||
namespace pocketmine\level\generator;
|
||||
|
||||
use pocketmine\block\Block;
|
||||
use pocketmine\level\format\FullChunk;
|
||||
use pocketmine\level\generator\biome\Biome;
|
||||
use pocketmine\level\Level;
|
||||
use pocketmine\level\SimpleChunkManager;
|
||||
use pocketmine\scheduler\AsyncTask;
|
||||
use pocketmine\Server;
|
||||
use pocketmine\utils\Random;
|
||||
|
||||
class GeneratorUnregisterTask extends AsyncTask{
|
||||
|
||||
public $levelId;
|
||||
|
||||
public function __construct(Level $level){
|
||||
$this->levelId = $level->getId();
|
||||
}
|
||||
|
||||
public function onRun(){
|
||||
$this->saveToThreadStore("generation.level{$this->levelId}.manager", null);
|
||||
$this->saveToThreadStore("generation.level{$this->levelId}.generator", null);
|
||||
}
|
||||
}
|
@ -32,9 +32,8 @@ use pocketmine\utils\Random;
|
||||
|
||||
class PopulationTask extends AsyncTask{
|
||||
|
||||
public $generator;
|
||||
public $settings;
|
||||
public $seed;
|
||||
|
||||
public $state;
|
||||
public $levelId;
|
||||
public $chunk;
|
||||
public $chunkClass;
|
||||
@ -49,10 +48,8 @@ class PopulationTask extends AsyncTask{
|
||||
public $chunk21;
|
||||
public $chunk22;
|
||||
|
||||
public function __construct(Level $level, Generator $generator, FullChunk $chunk){
|
||||
$this->generator = get_class($generator);
|
||||
$this->settings = $generator->getSettings();
|
||||
$this->seed = $level->getSeed();
|
||||
public function __construct(Level $level, FullChunk $chunk){
|
||||
$this->state = true;
|
||||
$this->levelId = $level->getId();
|
||||
$this->chunk = $chunk->toFastBinary();
|
||||
$this->chunkClass = get_class($chunk);
|
||||
@ -70,19 +67,12 @@ class PopulationTask extends AsyncTask{
|
||||
|
||||
public function onRun(){
|
||||
/** @var SimpleChunkManager $manager */
|
||||
$manager = $this->getFromThreadStore($key = "generation.level{$this->levelId}.manager");
|
||||
$manager = $this->getFromThreadStore("generation.level{$this->levelId}.manager");
|
||||
/** @var Generator $generator */
|
||||
$generator = $this->getFromThreadStore($gKey = "generation.level{$this->levelId}.generator");
|
||||
$generator = $this->getFromThreadStore("generation.level{$this->levelId}.generator");
|
||||
if($manager === null or $generator === null){
|
||||
Block::init();
|
||||
Biome::init();
|
||||
$manager = new SimpleChunkManager($this->seed);
|
||||
$this->saveToThreadStore($key, $manager);
|
||||
/** @var Generator $generator */
|
||||
$generator = $this->generator;
|
||||
$generator = new $generator($this->settings);
|
||||
$generator->init($manager, new Random($manager->getSeed()));
|
||||
$this->saveToThreadStore($gKey, $generator);
|
||||
$this->state = false;
|
||||
return;
|
||||
}
|
||||
|
||||
/** @var FullChunk[] $chunks */
|
||||
@ -149,6 +139,10 @@ class PopulationTask extends AsyncTask{
|
||||
public function onCompletion(Server $server){
|
||||
$level = $server->getLevel($this->levelId);
|
||||
if($level !== null){
|
||||
if($this->state === false){
|
||||
$level->registerGenerator();
|
||||
return;
|
||||
}
|
||||
/** @var FullChunk[] $chunks */
|
||||
$chunks = [];
|
||||
/** @var FullChunk $chunkC */
|
||||
|
Reference in New Issue
Block a user