direct message packet
This commit is contained in:
		
							parent
							
								
									161c0c94f8
								
							
						
					
					
						commit
						7808bf831c
					
				| @ -37,6 +37,7 @@ pub enum RecvShipPacket { | |||||||
|     MenuSelect(MenuSelect), |     MenuSelect(MenuSelect), | ||||||
|     CharData(CharData), |     CharData(CharData), | ||||||
|     Message(Message), |     Message(Message), | ||||||
|  |     DirectMessage(DirectMessage), | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl RecvServerPacket for RecvShipPacket { | impl RecvServerPacket for RecvShipPacket { | ||||||
| @ -46,6 +47,7 @@ impl RecvServerPacket for RecvShipPacket { | |||||||
|             0x10 => Ok(RecvShipPacket::MenuSelect(MenuSelect::from_bytes(data)?)), |             0x10 => Ok(RecvShipPacket::MenuSelect(MenuSelect::from_bytes(data)?)), | ||||||
|             0x61 => Ok(RecvShipPacket::CharData(CharData::from_bytes(data)?)), |             0x61 => Ok(RecvShipPacket::CharData(CharData::from_bytes(data)?)), | ||||||
|             0x60 => Ok(RecvShipPacket::Message(Message::from_bytes(data)?)), |             0x60 => Ok(RecvShipPacket::Message(Message::from_bytes(data)?)), | ||||||
|  |             0x62 => Ok(RecvShipPacket::DirectMessage(DirectMessage::from_bytes(data)?)), | ||||||
|             _ => Err(PacketParseError::WrongPacketForServerType(u16::from_le_bytes([data[2], data[3]]), data.to_vec())) |             _ => Err(PacketParseError::WrongPacketForServerType(u16::from_le_bytes([data[2], data[3]]), data.to_vec())) | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @ -60,6 +62,7 @@ pub enum SendShipPacket { | |||||||
|     CharDataRequest(CharDataRequest), |     CharDataRequest(CharDataRequest), | ||||||
|     JoinLobby(JoinLobby), |     JoinLobby(JoinLobby), | ||||||
|     Message(Message), |     Message(Message), | ||||||
|  |     DirectMessage(DirectMessage), | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl SendServerPacket for SendShipPacket { | impl SendServerPacket for SendShipPacket { | ||||||
| @ -72,6 +75,7 @@ impl SendServerPacket for SendShipPacket { | |||||||
|             SendShipPacket::CharDataRequest(pkt) => pkt.as_bytes(), |             SendShipPacket::CharDataRequest(pkt) => pkt.as_bytes(), | ||||||
|             SendShipPacket::JoinLobby(pkt) => pkt.as_bytes(), |             SendShipPacket::JoinLobby(pkt) => pkt.as_bytes(), | ||||||
|             SendShipPacket::Message(pkt) => pkt.as_bytes(), |             SendShipPacket::Message(pkt) => pkt.as_bytes(), | ||||||
|  |             SendShipPacket::DirectMessage(pkt) => pkt.as_bytes(), | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -224,9 +228,20 @@ impl<EG: EntityGateway> ShipServerState<EG> { | |||||||
| 
 | 
 | ||||||
|     fn message(&mut self, id: ClientId, msg: &Message) -> Box<dyn Iterator<Item = (ClientId, SendShipPacket)>> { |     fn message(&mut self, id: ClientId, msg: &Message) -> Box<dyn Iterator<Item = (ClientId, SendShipPacket)>> { | ||||||
|         let cmsg = msg.clone(); |         let cmsg = msg.clone(); | ||||||
|         Box::new(self.client_location.get_client_neighbors(id).into_iter().map(move |client| { |         Box::new(self.client_location.get_area_by_user(id).clients().iter() | ||||||
|             (client, SendShipPacket::Message(cmsg.clone())) |                  .filter(|client| client.client_id != id) | ||||||
|         })) |                  .map(move |client| { | ||||||
|  |                      (client.client_id, SendShipPacket::Message(cmsg.clone())) | ||||||
|  |                  }).collect::<Vec<_>>().into_iter()) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     fn direct_message(&mut self, id: ClientId, msg: &DirectMessage) -> Box<dyn Iterator<Item = (ClientId, SendShipPacket)>> { | ||||||
|  |         let cmsg = msg.clone(); | ||||||
|  |         Box::new(self.client_location.get_area_by_user(id).clients().iter() | ||||||
|  |                  .filter(|client| client.index == cmsg.flag as usize) | ||||||
|  |                  .map(|client| { | ||||||
|  |                      (client.client_id, SendShipPacket::DirectMessage(cmsg.clone())) | ||||||
|  |                  }).collect::<Vec<_>>().into_iter()) | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -267,7 +282,10 @@ impl<EG: EntityGateway> ServerState for ShipServerState<EG> { | |||||||
|             }, |             }, | ||||||
|             RecvShipPacket::Message(msg) => { |             RecvShipPacket::Message(msg) => { | ||||||
|                 self.message(id, msg) |                 self.message(id, msg) | ||||||
|             } |             }, | ||||||
|  |             RecvShipPacket::DirectMessage(msg) => { | ||||||
|  |                 self.direct_message(id, msg) | ||||||
|  |             }, | ||||||
|         }) |         }) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user