mirror of
				https://github.com/pmmp/PocketMine-MP.git
				synced 2025-10-20 15:41:33 +00:00 
			
		
		
		
	Merge branch 'minor-next' into major-next
This commit is contained in:
		
							
								
								
									
										2
									
								
								.github/workflows/discord-release-notify.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/discord-release-notify.yml
									
									
									
									
										vendored
									
									
								
							| @@ -13,7 +13,7 @@ jobs: | |||||||
|       - uses: actions/checkout@v3 |       - uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|       - name: Setup PHP and tools |       - name: Setup PHP and tools | ||||||
|         uses: shivammathur/setup-php@2.24.0 |         uses: shivammathur/setup-php@2.25.2 | ||||||
|         with: |         with: | ||||||
|           php-version: 8.1 |           php-version: 8.1 | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/workflows/draft-release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/draft-release.yml
									
									
									
									
										vendored
									
									
								
							| @@ -18,7 +18,7 @@ jobs: | |||||||
|           submodules: true |           submodules: true | ||||||
|  |  | ||||||
|       - name: Setup PHP |       - name: Setup PHP | ||||||
|         uses: shivammathur/setup-php@2.24.0 |         uses: shivammathur/setup-php@2.25.2 | ||||||
|         with: |         with: | ||||||
|           php-version: 8.1 |           php-version: 8.1 | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/workflows/main.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/main.yml
									
									
									
									
										vendored
									
									
								
							| @@ -206,7 +206,7 @@ jobs: | |||||||
|       - uses: actions/checkout@v3 |       - uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|       - name: Setup PHP and tools |       - name: Setup PHP and tools | ||||||
|         uses: shivammathur/setup-php@2.24.0 |         uses: shivammathur/setup-php@2.25.2 | ||||||
|         with: |         with: | ||||||
|           php-version: 8.1 |           php-version: 8.1 | ||||||
|           tools: php-cs-fixer:3.16 |           tools: php-cs-fixer:3.16 | ||||||
|   | |||||||
 Submodule build/php updated: b1d5c0d737...f2ece7b30d
									
								
							| @@ -71,3 +71,9 @@ Released 6th May 2023. | |||||||
| ## Fixes | ## Fixes | ||||||
| - Fixed players being forced into flight mode in every game mode. | - Fixed players being forced into flight mode in every game mode. | ||||||
|   - Moral of the story: do not assume anything in Mojang internals does what its name suggests... |   - Moral of the story: do not assume anything in Mojang internals does what its name suggests... | ||||||
|  |  | ||||||
|  | # 4.20.5 | ||||||
|  | Released 30th May 2023. | ||||||
|  |  | ||||||
|  | ## Fixes | ||||||
|  | - Fixed server crash due to a bug in upstream dependency [`netresearch/jsonmapper`](https://github.com/cweiske/JsonMapper). | ||||||
|   | |||||||
| @@ -69,3 +69,9 @@ Released 17th May 2023. | |||||||
| - Registered but ineligible ticking chunks are no longer rechecked every tick. | - Registered but ineligible ticking chunks are no longer rechecked every tick. | ||||||
|     - This was causing wasted cycles during async worker backlog. |     - This was causing wasted cycles during async worker backlog. | ||||||
|     - The internal system must call `markTickingChunkForRecheck()` whenever a ticking chunk's eligibility for ticking has potentially changed, rather than just when it has changed from a yes to a no. |     - The internal system must call `markTickingChunkForRecheck()` whenever a ticking chunk's eligibility for ticking has potentially changed, rather than just when it has changed from a yes to a no. | ||||||
|  |  | ||||||
|  | # 4.21.1 | ||||||
|  | Released 30th May 2023. | ||||||
|  |  | ||||||
|  | ## Fixes | ||||||
|  | - Fixed server crash due to a bug in upstream dependency [`netresearch/jsonmapper`](https://github.com/cweiske/JsonMapper). | ||||||
|   | |||||||
| @@ -33,7 +33,7 @@ | |||||||
|       "composer-runtime-api": "^2.0", |       "composer-runtime-api": "^2.0", | ||||||
|       "adhocore/json-comment": "^1.1", |       "adhocore/json-comment": "^1.1", | ||||||
|       "fgrosse/phpasn1": "^2.3", |       "fgrosse/phpasn1": "^2.3", | ||||||
|       "netresearch/jsonmapper": "^4.0", |       "netresearch/jsonmapper": "dev-array-in-string-property-error as 4.2.0", | ||||||
|       "pocketmine/bedrock-block-upgrade-schema": "~2.1.0+bedrock-1.19.80", |       "pocketmine/bedrock-block-upgrade-schema": "~2.1.0+bedrock-1.19.80", | ||||||
|       "pocketmine/bedrock-data": "~2.2.0+bedrock-1.19.80", |       "pocketmine/bedrock-data": "~2.2.0+bedrock-1.19.80", | ||||||
|       "pocketmine/bedrock-item-upgrade-schema": "~1.2.0+bedrock-1.19.80", |       "pocketmine/bedrock-item-upgrade-schema": "~1.2.0+bedrock-1.19.80", | ||||||
| @@ -50,13 +50,13 @@ | |||||||
|       "pocketmine/raklib-ipc": "^0.2.0", |       "pocketmine/raklib-ipc": "^0.2.0", | ||||||
|       "pocketmine/snooze": "^0.5.0", |       "pocketmine/snooze": "^0.5.0", | ||||||
|       "ramsey/uuid": "^4.1", |       "ramsey/uuid": "^4.1", | ||||||
|       "symfony/filesystem": "^5.4" |       "symfony/filesystem": "^6.2" | ||||||
|    }, |    }, | ||||||
|    "require-dev": { |    "require-dev": { | ||||||
|       "phpstan/phpstan": "1.10.15", |       "phpstan/phpstan": "1.10.15", | ||||||
|       "phpstan/phpstan-phpunit": "^1.1.0", |       "phpstan/phpstan-phpunit": "^1.1.0", | ||||||
|       "phpstan/phpstan-strict-rules": "^1.2.0", |       "phpstan/phpstan-strict-rules": "^1.2.0", | ||||||
|       "phpunit/phpunit": "^9.2" |       "phpunit/phpunit": "^10.1" | ||||||
|    }, |    }, | ||||||
|    "autoload": { |    "autoload": { | ||||||
|       "psr-4": { |       "psr-4": { | ||||||
| @@ -90,5 +90,11 @@ | |||||||
|       "update-translation-apis": [ |       "update-translation-apis": [ | ||||||
|          "@php build/generate-known-translation-apis.php" |          "@php build/generate-known-translation-apis.php" | ||||||
|       ] |       ] | ||||||
|    } |    }, | ||||||
|  |    "repositories": [ | ||||||
|  |       { | ||||||
|  |          "type": "vcs", | ||||||
|  |          "url": "https://github.com/dktapps/JsonMapper.git" | ||||||
|  |       } | ||||||
|  |    ] | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										722
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										722
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -39,6 +39,7 @@ class PlayerDeathEvent extends EntityDeathEvent{ | |||||||
| 	protected Player $player; | 	protected Player $player; | ||||||
|  |  | ||||||
| 	private Translatable|string $deathMessage; | 	private Translatable|string $deathMessage; | ||||||
|  | 	private Translatable|string $deathScreenMessage; | ||||||
| 	private bool $keepInventory = false; | 	private bool $keepInventory = false; | ||||||
| 	private bool $keepXp = false; | 	private bool $keepXp = false; | ||||||
|  |  | ||||||
| @@ -50,6 +51,7 @@ class PlayerDeathEvent extends EntityDeathEvent{ | |||||||
| 		parent::__construct($entity, $drops, $xp); | 		parent::__construct($entity, $drops, $xp); | ||||||
| 		$this->player = $entity; | 		$this->player = $entity; | ||||||
| 		$this->deathMessage = $deathMessage ?? self::deriveMessage($entity->getDisplayName(), $entity->getLastDamageCause()); | 		$this->deathMessage = $deathMessage ?? self::deriveMessage($entity->getDisplayName(), $entity->getLastDamageCause()); | ||||||
|  | 		$this->deathScreenMessage = $this->deathMessage; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/** | 	/** | ||||||
| @@ -71,6 +73,14 @@ class PlayerDeathEvent extends EntityDeathEvent{ | |||||||
| 		$this->deathMessage = $deathMessage; | 		$this->deathMessage = $deathMessage; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	public function getDeathScreenMessage() : Translatable|string{ | ||||||
|  | 		return $this->deathScreenMessage; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	public function setDeathScreenMessage(Translatable|string $deathScreenMessage) : void{ | ||||||
|  | 		$this->deathScreenMessage = $deathScreenMessage; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	public function getKeepInventory() : bool{ | 	public function getKeepInventory() : bool{ | ||||||
| 		return $this->keepInventory; | 		return $this->keepInventory; | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -27,16 +27,24 @@ use pocketmine\crafting\CraftingManagerFromDataHelper; | |||||||
| use pocketmine\crafting\json\ItemStackData; | use pocketmine\crafting\json\ItemStackData; | ||||||
| use pocketmine\data\bedrock\BedrockDataFiles; | use pocketmine\data\bedrock\BedrockDataFiles; | ||||||
| use pocketmine\item\Item; | use pocketmine\item\Item; | ||||||
|  | use pocketmine\utils\DestructorCallbackTrait; | ||||||
|  | use pocketmine\utils\Filesystem; | ||||||
|  | use pocketmine\utils\ObjectSet; | ||||||
| use pocketmine\utils\SingletonTrait; | use pocketmine\utils\SingletonTrait; | ||||||
| use pocketmine\utils\Utils; | use pocketmine\utils\Utils; | ||||||
|  |  | ||||||
| final class CreativeInventory{ | final class CreativeInventory{ | ||||||
| 	use SingletonTrait; | 	use SingletonTrait; | ||||||
|  | 	use DestructorCallbackTrait; | ||||||
|  |  | ||||||
| 	/** @var Item[] */ | 	/** @var Item[] */ | ||||||
| 	private array $creative = []; | 	private array $creative = []; | ||||||
|  |  | ||||||
|  | 	/** @phpstan-var ObjectSet<\Closure() : void> */ | ||||||
|  | 	private ObjectSet $contentChangedCallbacks; | ||||||
|  |  | ||||||
| 	private function __construct(){ | 	private function __construct(){ | ||||||
|  | 		$this->contentChangedCallbacks = new ObjectSet(); | ||||||
| 		$creativeItems = CraftingManagerFromDataHelper::loadJsonArrayOfObjectsFile( | 		$creativeItems = CraftingManagerFromDataHelper::loadJsonArrayOfObjectsFile( | ||||||
| 			BedrockDataFiles::CREATIVEITEMS_JSON, | 			BedrockDataFiles::CREATIVEITEMS_JSON, | ||||||
| 			ItemStackData::class | 			ItemStackData::class | ||||||
| @@ -57,6 +65,7 @@ final class CreativeInventory{ | |||||||
| 	 */ | 	 */ | ||||||
| 	public function clear() : void{ | 	public function clear() : void{ | ||||||
| 		$this->creative = []; | 		$this->creative = []; | ||||||
|  | 		$this->onContentChange(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/** | 	/** | ||||||
| @@ -86,6 +95,7 @@ final class CreativeInventory{ | |||||||
| 	 */ | 	 */ | ||||||
| 	public function add(Item $item) : void{ | 	public function add(Item $item) : void{ | ||||||
| 		$this->creative[] = clone $item; | 		$this->creative[] = clone $item; | ||||||
|  | 		$this->onContentChange(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/** | 	/** | ||||||
| @@ -96,10 +106,22 @@ final class CreativeInventory{ | |||||||
| 		$index = $this->getItemIndex($item); | 		$index = $this->getItemIndex($item); | ||||||
| 		if($index !== -1){ | 		if($index !== -1){ | ||||||
| 			unset($this->creative[$index]); | 			unset($this->creative[$index]); | ||||||
|  | 			$this->onContentChange(); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function contains(Item $item) : bool{ | 	public function contains(Item $item) : bool{ | ||||||
| 		return $this->getItemIndex($item) !== -1; | 		return $this->getItemIndex($item) !== -1; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	/** @phpstan-return ObjectSet<\Closure() : void> */ | ||||||
|  | 	public function getContentChangedCallbacks() : ObjectSet{ | ||||||
|  | 		return $this->contentChangedCallbacks; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	private function onContentChange() : void{ | ||||||
|  | 		foreach($this->contentChangedCallbacks as $callback){ | ||||||
|  | 			$callback(); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -39,18 +39,16 @@ use pocketmine\inventory\CreativeInventory; | |||||||
| use pocketmine\inventory\Inventory; | use pocketmine\inventory\Inventory; | ||||||
| use pocketmine\inventory\transaction\action\SlotChangeAction; | use pocketmine\inventory\transaction\action\SlotChangeAction; | ||||||
| use pocketmine\inventory\transaction\InventoryTransaction; | use pocketmine\inventory\transaction\InventoryTransaction; | ||||||
| use pocketmine\item\Item; | use pocketmine\network\mcpe\cache\CreativeInventoryCache; | ||||||
| use pocketmine\network\mcpe\protocol\ClientboundPacket; | use pocketmine\network\mcpe\protocol\ClientboundPacket; | ||||||
| use pocketmine\network\mcpe\protocol\ContainerClosePacket; | use pocketmine\network\mcpe\protocol\ContainerClosePacket; | ||||||
| use pocketmine\network\mcpe\protocol\ContainerOpenPacket; | use pocketmine\network\mcpe\protocol\ContainerOpenPacket; | ||||||
| use pocketmine\network\mcpe\protocol\ContainerSetDataPacket; | use pocketmine\network\mcpe\protocol\ContainerSetDataPacket; | ||||||
| use pocketmine\network\mcpe\protocol\CreativeContentPacket; |  | ||||||
| use pocketmine\network\mcpe\protocol\InventoryContentPacket; | use pocketmine\network\mcpe\protocol\InventoryContentPacket; | ||||||
| use pocketmine\network\mcpe\protocol\InventorySlotPacket; | use pocketmine\network\mcpe\protocol\InventorySlotPacket; | ||||||
| use pocketmine\network\mcpe\protocol\MobEquipmentPacket; | use pocketmine\network\mcpe\protocol\MobEquipmentPacket; | ||||||
| use pocketmine\network\mcpe\protocol\types\BlockPosition; | use pocketmine\network\mcpe\protocol\types\BlockPosition; | ||||||
| use pocketmine\network\mcpe\protocol\types\inventory\ContainerIds; | use pocketmine\network\mcpe\protocol\types\inventory\ContainerIds; | ||||||
| use pocketmine\network\mcpe\protocol\types\inventory\CreativeContentEntry; |  | ||||||
| use pocketmine\network\mcpe\protocol\types\inventory\ItemStack; | use pocketmine\network\mcpe\protocol\types\inventory\ItemStack; | ||||||
| use pocketmine\network\mcpe\protocol\types\inventory\ItemStackWrapper; | use pocketmine\network\mcpe\protocol\types\inventory\ItemStackWrapper; | ||||||
| use pocketmine\network\mcpe\protocol\types\inventory\NetworkInventoryAction; | use pocketmine\network\mcpe\protocol\types\inventory\NetworkInventoryAction; | ||||||
| @@ -605,16 +603,7 @@ class InventoryManager{ | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function syncCreative() : void{ | 	public function syncCreative() : void{ | ||||||
| 		$typeConverter = $this->session->getTypeConverter(); | 		$this->session->sendDataPacket(CreativeInventoryCache::getInstance()->getCache(CreativeInventory::getInstance())); | ||||||
|  |  | ||||||
| 		$entries = []; |  | ||||||
| 		if(!$this->player->isSpectator()){ |  | ||||||
| 			//creative inventory may have holes if items were unregistered - ensure network IDs used are always consistent |  | ||||||
| 			foreach(CreativeInventory::getInstance()->getAll() as $k => $item){ |  | ||||||
| 				$entries[] = new CreativeContentEntry($k, $typeConverter->coreItemStackToNet($item)); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 		$this->session->sendDataPacket(CreativeContentPacket::create($entries)); |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	private function newItemStackId() : int{ | 	private function newItemStackId() : int{ | ||||||
|   | |||||||
							
								
								
									
										69
									
								
								src/network/mcpe/cache/CreativeInventoryCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								src/network/mcpe/cache/CreativeInventoryCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | |||||||
|  | <?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/ | ||||||
|  |  * | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | declare(strict_types=1); | ||||||
|  |  | ||||||
|  | namespace pocketmine\network\mcpe\cache; | ||||||
|  |  | ||||||
|  | use pocketmine\inventory\CreativeInventory; | ||||||
|  | use pocketmine\network\mcpe\convert\TypeConverter; | ||||||
|  | use pocketmine\network\mcpe\protocol\CreativeContentPacket; | ||||||
|  | use pocketmine\network\mcpe\protocol\types\inventory\CreativeContentEntry; | ||||||
|  | use pocketmine\utils\SingletonTrait; | ||||||
|  | use function spl_object_id; | ||||||
|  |  | ||||||
|  | final class CreativeInventoryCache{ | ||||||
|  | 	use SingletonTrait; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @var CreativeContentPacket[] | ||||||
|  | 	 * @phpstan-var array<int, CreativeContentPacket> | ||||||
|  | 	 */ | ||||||
|  | 	private array $caches = []; | ||||||
|  |  | ||||||
|  | 	public function getCache(CreativeInventory $inventory) : CreativeContentPacket{ | ||||||
|  | 		$id = spl_object_id($inventory); | ||||||
|  | 		if(!isset($this->caches[$id])){ | ||||||
|  | 			$inventory->getDestructorCallbacks()->add(function() use ($id) : void{ | ||||||
|  | 				unset($this->caches[$id]); | ||||||
|  | 			}); | ||||||
|  | 			$inventory->getContentChangedCallbacks()->add(function() use ($id) : void{ | ||||||
|  | 				unset($this->caches[$id]); | ||||||
|  | 			}); | ||||||
|  | 			$this->caches[$id] = $this->buildCreativeInventoryCache($inventory); | ||||||
|  | 		} | ||||||
|  | 		return $this->caches[$id]; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Rebuild the cache for the given inventory. | ||||||
|  | 	 */ | ||||||
|  | 	private function buildCreativeInventoryCache(CreativeInventory $inventory) : CreativeContentPacket{ | ||||||
|  | 		$entries = []; | ||||||
|  | 		$typeConverter = TypeConverter::getInstance(); | ||||||
|  | 		//creative inventory may have holes if items were unregistered - ensure network IDs used are always consistent | ||||||
|  | 		foreach($inventory->getAll() as $k => $item){ | ||||||
|  | 			$entries[] = new CreativeContentEntry($k, $typeConverter->coreItemStackToNet($item)); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return CreativeContentPacket::create($entries); | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @@ -2350,7 +2350,7 @@ class Player extends Human implements CommandSender, ChunkListener, IPlayer{ | |||||||
|  |  | ||||||
| 		$this->startDeathAnimation(); | 		$this->startDeathAnimation(); | ||||||
|  |  | ||||||
| 		$this->getNetworkSession()->onServerDeath($ev->getDeathMessage()); | 		$this->getNetworkSession()->onServerDeath($ev->getDeathScreenMessage()); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	protected function onDeathUpdate(int $tickDiff) : bool{ | 	protected function onDeathUpdate(int $tickDiff) : bool{ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user