Merge pull request 'dont forget to send client location packets to other clients' (#192) from sync_player_positions into master
Reviewed-by: jake <jake@sharnoth.com>
This commit is contained in:
		
						commit
						379935ca74
					
				| @ -162,7 +162,7 @@ where | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| pub fn update_player_position(id: ClientId, | pub fn update_player_position(id: ClientId, | ||||||
|                             message: &GameMessage, |                             message: &Message, | ||||||
|                             clients: &mut Clients, |                             clients: &mut Clients, | ||||||
|                             client_location: &ClientLocation, |                             client_location: &ClientLocation, | ||||||
|                             rooms: &Rooms) |                             rooms: &Rooms) | ||||||
| @ -174,7 +174,7 @@ pub fn update_player_position(id: ClientId, | |||||||
|             .as_ref() |             .as_ref() | ||||||
|             .ok_or_else(|| ShipError::InvalidRoom(room_id.0 as u32))?; |             .ok_or_else(|| ShipError::InvalidRoom(room_id.0 as u32))?; | ||||||
|         
 |         
 | ||||||
|         match message { |         match &message.msg { | ||||||
|             GameMessage::PlayerChangedMap(p) => {client.x = p.x; client.y = p.y; client.z = p.z;}, |             GameMessage::PlayerChangedMap(p) => {client.x = p.x; client.y = p.y; client.z = p.z;}, | ||||||
|             GameMessage::PlayerChangedMap2(p) => {client.area = MapArea::from_value(&room.mode.episode(), p.map_area).ok();}, |             GameMessage::PlayerChangedMap2(p) => {client.area = MapArea::from_value(&room.mode.episode(), p.map_area).ok();}, | ||||||
|             GameMessage::TellOtherPlayerMyLocation(p) => {client.x = p.x; client.y = p.y; client.z = p.z; client.area = MapArea::from_value(&room.mode.episode(), p.map_area).ok();}, |             GameMessage::TellOtherPlayerMyLocation(p) => {client.x = p.x; client.y = p.y; client.z = p.z; client.area = MapArea::from_value(&room.mode.episode(), p.map_area).ok();}, | ||||||
| @ -190,7 +190,11 @@ pub fn update_player_position(id: ClientId, | |||||||
|             _ => {}, |             _ => {}, | ||||||
|         } |         } | ||||||
|     } else {} |     } else {} | ||||||
|     Ok(Box::new(None.into_iter())) |     let m = message.clone(); | ||||||
|  |     Ok(Box::new(client_location.get_client_neighbors(id).unwrap().into_iter() | ||||||
|  |                     .map(move |client| { | ||||||
|  |                         (client.client, SendShipPacket::Message(m.clone())) | ||||||
|  |                     }))) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| pub async fn charge_attack<EG>(id: ClientId, | pub async fn charge_attack<EG>(id: ClientId, | ||||||
|  | |||||||
| @ -290,7 +290,7 @@ impl<EG: EntityGateway> ShipServerState<EG> { | |||||||
|             GameMessage::PlayerWarpingToFloor(_) | GameMessage::PlayerTeleported(_) | GameMessage::PlayerStopped(_) | 
 |             GameMessage::PlayerWarpingToFloor(_) | GameMessage::PlayerTeleported(_) | GameMessage::PlayerStopped(_) | 
 | ||||||
|             GameMessage::PlayerLoadedIn(_) | GameMessage::PlayerWalking(_) | GameMessage::PlayerRunning(_) | 
 |             GameMessage::PlayerLoadedIn(_) | GameMessage::PlayerWalking(_) | GameMessage::PlayerRunning(_) | 
 | ||||||
|             GameMessage::PlayerWarped(_) | GameMessage::PlayerChangedFloor(_) | GameMessage::InitializeSpeechNpc(_) => { |             GameMessage::PlayerWarped(_) | GameMessage::PlayerChangedFloor(_) | GameMessage::InitializeSpeechNpc(_) => { | ||||||
|                 handler::message::update_player_position(id, &msg.msg, &mut self.clients, &mut self.client_location, &self.rooms) |                 handler::message::update_player_position(id, &msg, &mut self.clients, &mut self.client_location, &self.rooms) | ||||||
|             }, |             }, | ||||||
|             GameMessage::ChargeAttack(charge_attack) => { |             GameMessage::ChargeAttack(charge_attack) => { | ||||||
|                 handler::message::charge_attack(id, charge_attack, &mut self.clients, &mut self.entity_gateway).await |                 handler::message::charge_attack(id, charge_attack, &mut self.clients, &mut self.entity_gateway).await | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user