mirror of
				https://github.com/pmmp/PocketMine-MP.git
				synced 2025-10-20 15:41:33 +00:00 
			
		
		
		
	Merge remote-tracking branch 'origin/stable' into minor-next
This commit is contained in:
		| @@ -113,7 +113,12 @@ class ItemStackRequestExecutor{ | ||||
| 	 */ | ||||
| 	protected function getBuilderInventoryAndSlot(ItemStackRequestSlotInfo $info) : array{ | ||||
| 		$windowId = ItemStackContainerIdTranslator::translate($info->getContainerId(), $this->inventoryManager->getCurrentWindowId()); | ||||
| 		$windowAndSlot = $this->inventoryManager->locateWindowAndSlot($windowId, $info->getSlotId()); | ||||
| 		$slotId = $info->getSlotId(); | ||||
| 		if($info->getContainerId() === ContainerUIIds::OFFHAND && $slotId === 1){ | ||||
| 			//TODO: HACK! The client sends an incorrect slot ID for the offhand as of 1.19.70 | ||||
| 			$slotId = 0; | ||||
| 		} | ||||
| 		$windowAndSlot = $this->inventoryManager->locateWindowAndSlot($windowId, $slotId); | ||||
| 		if($windowAndSlot === null){ | ||||
| 			throw new ItemStackRequestProcessException("No open inventory matches container UI ID: " . $info->getContainerId() . ", slot ID: " . $info->getSlotId()); | ||||
| 		} | ||||
|   | ||||
| @@ -53,6 +53,10 @@ final class ItemStackResponseBuilder{ | ||||
| 	 * @phpstan-return array{Inventory, int} | ||||
| 	 */ | ||||
| 	private function getInventoryAndSlot(int $containerInterfaceId, int $slotId) : ?array{ | ||||
| 		if($containerInterfaceId === ContainerUIIds::OFFHAND && $slotId === 1){ | ||||
| 			//TODO: HACK! The client sends an incorrect slot ID for the offhand as of 1.19.70 | ||||
| 			$slotId = 0; | ||||
| 		} | ||||
| 		$windowId = ItemStackContainerIdTranslator::translate($containerInterfaceId, $this->inventoryManager->getCurrentWindowId()); | ||||
| 		$windowAndSlot = $this->inventoryManager->locateWindowAndSlot($windowId, $slotId); | ||||
| 		if($windowAndSlot === null){ | ||||
|   | ||||
| @@ -28,6 +28,7 @@ use pocketmine\entity\Entity; | ||||
| use pocketmine\event\Event; | ||||
| use pocketmine\network\mcpe\protocol\ClientboundPacket; | ||||
| use pocketmine\network\mcpe\protocol\ServerboundPacket; | ||||
| use pocketmine\player\Player; | ||||
| use pocketmine\scheduler\TaskHandler; | ||||
| use function get_class; | ||||
|  | ||||
| @@ -241,8 +242,14 @@ abstract class Timings{ | ||||
| 	} | ||||
|  | ||||
| 	public static function getEntityTimings(Entity $entity) : TimingsHandler{ | ||||
| 		$entityType = (new \ReflectionClass($entity))->getShortName(); | ||||
| 		$reflect = new \ReflectionClass($entity); | ||||
| 		$entityType = $reflect->getShortName(); | ||||
| 		if(!isset(self::$entityTypeTimingMap[$entityType])){ | ||||
| 			//the timings viewer calculates average player count by looking at this timer, so we need to ensure it has | ||||
| 			//a name it can identify. However, we also want to make it obvious if this is a custom Player class. | ||||
| 			if($entity instanceof Player && $reflect->getName() !== Player::class){ | ||||
| 				$entityType = "Player (" . $reflect->getName() . ")"; | ||||
| 			} | ||||
| 			self::$entityTypeTimingMap[$entityType] = new TimingsHandler(self::INCLUDED_BY_OTHER_TIMINGS_PREFIX . "Entity Tick - " . $entityType, self::$tickEntity); | ||||
| 		} | ||||
|  | ||||
|   | ||||
| @@ -25,7 +25,7 @@ namespace pocketmine\timings; | ||||
|  | ||||
| use pocketmine\Server; | ||||
| use pocketmine\utils\AssumptionFailedError; | ||||
| use function round; | ||||
| use function floor; | ||||
| use function spl_object_id; | ||||
|  | ||||
| /** | ||||
| @@ -60,7 +60,7 @@ final class TimingsRecord{ | ||||
| 		if($measure){ | ||||
| 			foreach(self::$records as $record){ | ||||
| 				if($record->curTickTotal > Server::TARGET_NANOSECONDS_PER_TICK){ | ||||
| 					$record->violations += (int) round($record->curTickTotal / Server::TARGET_NANOSECONDS_PER_TICK); | ||||
| 					$record->violations += (int) floor($record->curTickTotal / Server::TARGET_NANOSECONDS_PER_TICK); | ||||
| 				} | ||||
| 				$record->curTickTotal = 0; | ||||
| 				$record->curCount = 0; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user