From 3a3d0fc3d4733f8908e23a03f860d76340479ec4 Mon Sep 17 00:00:00 2001 From: Dennis Kobert Date: Tue, 11 Jun 2019 23:53:30 +0200 Subject: Reorganize Project structure --- game_server/src/lobby.rs | 63 ------------------------------------------------ 1 file changed, 63 deletions(-) delete mode 100644 game_server/src/lobby.rs (limited to 'game_server/src/lobby.rs') diff --git a/game_server/src/lobby.rs b/game_server/src/lobby.rs deleted file mode 100644 index 6d11a5f..0000000 --- a/game_server/src/lobby.rs +++ /dev/null @@ -1,63 +0,0 @@ -use std::collections::HashMap; - -use crate::group::{Group, GroupId}; -use crate::scribble_group::ScribbleGroup; - -use crate::server::{UserId, GameClient, GameServerError}; - -pub struct Lobby { - groups: HashMap>, -} - -#[allow(dead_code)] -impl Lobby { - pub fn new() -> Self { - Self { - groups: HashMap::new(), - } - } - - fn generate_group(group_type: &str, id: GroupId, name: &str) -> Option> { - match group_type { - "scribble" => { - Some(Box::new(ScribbleGroup::new(id, name.to_string()))) - }, - _ => None, - } - } - - pub fn add_group(&mut self, group: Box) { - self.groups.insert(group.id(), group); - } - - pub fn add_client(&mut self, group_type: &str, group_id: GroupId, group_name: &str, - user_id: UserId, client: GameClient) -> Result<(), GameServerError> { - if !self.groups.contains_key(&group_id) { - let mut group = match Self::generate_group(group_type, group_id, group_name) { - Some(x) => x, - _ => return Err(GameServerError::GroupCreationError(format!("failed to generate '{}' group", group_type))), - }; - group.run(); - self.groups.insert(group_id, group); - } - let group = self.groups.get_mut(&group_id).unwrap(); - group.add_client(user_id, client) - } - - pub fn iter<'b>(&'b self) -> GroupIterator<'b> { - GroupIterator { groups: self.groups.values() } - } -} - -#[allow(dead_code)] -pub struct GroupIterator<'a> { - groups: std::collections::hash_map::Values<'a, GroupId, Box> -} - -impl<'a> Iterator for GroupIterator<'a> { - type Item = &'a Box; - - fn next(&mut self) -> Option { - self.groups.next() - } -} -- cgit v1.2.3-54-g00ecf