mirror of
				https://github.com/pmmp/PocketMine-MP.git
				synced 2025-10-20 15:41:33 +00:00 
			
		
		
		
	Player: prevent PlayerToggle(Sprint|Sneak|Fly|Glide|Swim)Events from firing multiple times with the same value
this happens with swimming due to bugs in the client.
This commit is contained in:
		| @@ -1743,6 +1743,9 @@ class Player extends Human implements CommandSender, ChunkListener, IPlayer{ | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function toggleSprint(bool $sprint) : bool{ | 	public function toggleSprint(bool $sprint) : bool{ | ||||||
|  | 		if($sprint === $this->sprinting){ | ||||||
|  | 			return true; | ||||||
|  | 		} | ||||||
| 		$ev = new PlayerToggleSprintEvent($this, $sprint); | 		$ev = new PlayerToggleSprintEvent($this, $sprint); | ||||||
| 		$ev->call(); | 		$ev->call(); | ||||||
| 		if($ev->isCancelled()){ | 		if($ev->isCancelled()){ | ||||||
| @@ -1753,6 +1756,9 @@ class Player extends Human implements CommandSender, ChunkListener, IPlayer{ | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function toggleSneak(bool $sneak) : bool{ | 	public function toggleSneak(bool $sneak) : bool{ | ||||||
|  | 		if($sneak === $this->sneaking){ | ||||||
|  | 			return true; | ||||||
|  | 		} | ||||||
| 		$ev = new PlayerToggleSneakEvent($this, $sneak); | 		$ev = new PlayerToggleSneakEvent($this, $sneak); | ||||||
| 		$ev->call(); | 		$ev->call(); | ||||||
| 		if($ev->isCancelled()){ | 		if($ev->isCancelled()){ | ||||||
| @@ -1763,6 +1769,9 @@ class Player extends Human implements CommandSender, ChunkListener, IPlayer{ | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function toggleFlight(bool $fly) : bool{ | 	public function toggleFlight(bool $fly) : bool{ | ||||||
|  | 		if($fly === $this->flying){ | ||||||
|  | 			return true; | ||||||
|  | 		} | ||||||
| 		$ev = new PlayerToggleFlightEvent($this, $fly); | 		$ev = new PlayerToggleFlightEvent($this, $fly); | ||||||
| 		if(!$this->allowFlight){ | 		if(!$this->allowFlight){ | ||||||
| 			$ev->cancel(); | 			$ev->cancel(); | ||||||
| @@ -1778,6 +1787,9 @@ class Player extends Human implements CommandSender, ChunkListener, IPlayer{ | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function toggleGlide(bool $glide) : bool{ | 	public function toggleGlide(bool $glide) : bool{ | ||||||
|  | 		if($glide === $this->gliding){ | ||||||
|  | 			return true; | ||||||
|  | 		} | ||||||
| 		$ev = new PlayerToggleGlideEvent($this, $glide); | 		$ev = new PlayerToggleGlideEvent($this, $glide); | ||||||
| 		$ev->call(); | 		$ev->call(); | ||||||
| 		if($ev->isCancelled()){ | 		if($ev->isCancelled()){ | ||||||
| @@ -1788,6 +1800,9 @@ class Player extends Human implements CommandSender, ChunkListener, IPlayer{ | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function toggleSwim(bool $swimming) : bool{ | 	public function toggleSwim(bool $swimming) : bool{ | ||||||
|  | 		if($swimming === $this->swimming){ | ||||||
|  | 			return true; | ||||||
|  | 		} | ||||||
| 		$ev = new PlayerToggleSwimEvent($this, $swimming); | 		$ev = new PlayerToggleSwimEvent($this, $swimming); | ||||||
| 		$ev->call(); | 		$ev->call(); | ||||||
| 		if($ev->isCancelled()){ | 		if($ev->isCancelled()){ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user