mirror of
https://github.com/pmmp/PocketMine-MP.git
synced 2025-06-13 15:05:33 +00:00
Merge branch 'minor-next' into major-next
This commit is contained in:
commit
0ed5e94a72
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
|
||||||
|
@ -1 +1 @@
|
|||||||
Subproject commit b1d5c0d737be86538bb35e1408cd53a616de5a27
|
Subproject commit f2ece7b30d0364eebf1d79497003cfda1dc41aa8
|
@ -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{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user