summaryrefslogtreecommitdiff
path: root/game_server/src/lobby.rs
diff options
context:
space:
mode:
Diffstat (limited to 'game_server/src/lobby.rs')
-rw-r--r--game_server/src/lobby.rs12
1 files changed, 6 insertions, 6 deletions
diff --git a/game_server/src/lobby.rs b/game_server/src/lobby.rs
index ef164af..6d11a5f 100644
--- a/game_server/src/lobby.rs
+++ b/game_server/src/lobby.rs
@@ -1,9 +1,9 @@
use std::collections::HashMap;
-use super::group::{Group, GroupId};
-use super::scribble_group::ScribbleGroup;
+use crate::group::{Group, GroupId};
+use crate::scribble_group::ScribbleGroup;
-use super::server::{UserId, GameClient};
+use crate::server::{UserId, GameClient, GameServerError};
pub struct Lobby {
groups: HashMap<GroupId, Box<Group>>,
@@ -31,17 +31,17 @@ impl Lobby {
}
pub fn add_client(&mut self, group_type: &str, group_id: GroupId, group_name: &str,
- user_id: UserId, client: GameClient) {
+ 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,
+ _ => 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);
+ group.add_client(user_id, client)
}
pub fn iter<'b>(&'b self) -> GroupIterator<'b> {