From 3ec2994d7f05f30e2519430379ae0f3106be5074 Mon Sep 17 00:00:00 2001 From: "Dylan K. Taylor" Date: Wed, 20 May 2020 11:53:35 +0100 Subject: [PATCH] added protocol GameMode constants --- src/pocketmine/Player.php | 14 ++++--- .../network/mcpe/protocol/types/GameMode.php | 38 +++++++++++++++++++ 2 files changed, 46 insertions(+), 6 deletions(-) create mode 100644 src/pocketmine/network/mcpe/protocol/types/GameMode.php diff --git a/src/pocketmine/Player.php b/src/pocketmine/Player.php index 405e8563b..0f2cdd8d7 100644 --- a/src/pocketmine/Player.php +++ b/src/pocketmine/Player.php @@ -146,6 +146,7 @@ use pocketmine\network\mcpe\protocol\types\CommandEnum; use pocketmine\network\mcpe\protocol\types\CommandParameter; use pocketmine\network\mcpe\protocol\types\ContainerIds; use pocketmine\network\mcpe\protocol\types\DimensionIds; +use pocketmine\network\mcpe\protocol\types\GameMode; use pocketmine\network\mcpe\protocol\types\PersonaPieceTintColor; use pocketmine\network\mcpe\protocol\types\PersonaSkinPiece; use pocketmine\network\mcpe\protocol\types\PlayerPermissions; @@ -1333,12 +1334,13 @@ class Player extends Human implements CommandSender, ChunkLoader, IPlayer{ * TODO: remove this when Spectator Mode gets added properly to MCPE */ public static function getClientFriendlyGamemode(int $gamemode) : int{ - $gamemode &= 0x03; - if($gamemode === Player::SPECTATOR){ - return Player::CREATIVE; - } - - return $gamemode; + static $map = [ + self::SURVIVAL => GameMode::SURVIVAL, + self::CREATIVE => GameMode::CREATIVE, + self::ADVENTURE => GameMode::ADVENTURE, + self::SPECTATOR => GameMode::CREATIVE + ]; + return $map[$gamemode & 0x3]; } /** diff --git a/src/pocketmine/network/mcpe/protocol/types/GameMode.php b/src/pocketmine/network/mcpe/protocol/types/GameMode.php new file mode 100644 index 000000000..616c92259 --- /dev/null +++ b/src/pocketmine/network/mcpe/protocol/types/GameMode.php @@ -0,0 +1,38 @@ +