i hate borrow

master
bel 2020-05-03 15:13:37 -06:00
parent 5fbb620f85
commit f27795d303
4 changed files with 27 additions and 22 deletions

View File

@ -33,25 +33,27 @@ impl GameMaster {
self.run_game() self.run_game()
} }
fn run_lobby(&mut self) -> Result<usize, &str> { fn run_lobby(&mut self) -> Result<usize, String> {
self.run_lobby_loop()?; let mut r = self.run_lobby_scrape();
self.lobby.ready() while r.unwrap_or(0) == 0 {
} //while r.is_ok() && r.unwrap() == 0 {
fn run_lobby_loop(&mut self) -> Result<usize, &str> {
while !self.lobby.locked {
self.run_lobby_scrape()?;
thread::sleep(time::Duration::new(1, 0)); thread::sleep(time::Duration::new(1, 0));
r = self.run_lobby_scrape();
} }
Ok(0) return Ok(r.unwrap().clone());
/*
if r.is_ok() {
return Ok(r.unwrap());
}
let e = r.err();
Err(e.unwrap())
*/
} }
fn run_lobby_scrape(&mut self) -> Result<usize, &str> { fn run_lobby_scrape(&mut self) -> Result<usize, String> {
/*
let rollback = self.room.since();
let events = self.room.sync(); let events = self.room.sync();
for e in &events { for e in &events {
let ge = GameEvent::new(e.body.clone()); let ge = GameEvent::new(e.clone());
if ge.mode() == GameEventType::GameStart { if ge.mode() == GameEventType::GameStart {
self.room.rollback(e.since.clone()); self.room.rollback(e.since.clone());
self.lobby.lock(); self.lobby.lock();
@ -59,7 +61,6 @@ impl GameMaster {
} }
self.lobby.eat(e.clone()); self.lobby.eat(e.clone());
} }
*/
Ok(0) Ok(0)
} }
@ -131,11 +132,15 @@ mod tests {
#[test] #[test]
fn run_lobby() { fn run_lobby() {
init(); init();
println!("run_lobby 1");
let mut mrs = MockRooms::new(); let mut mrs = MockRooms::new();
let r1 = mrs.create(); let r1 = mrs.create();
println!("run_lobby 2");
let room_id = r1.room_id(); let room_id = r1.room_id();
let mut gm = GameMaster::new(r1); let mut gm = GameMaster::new(r1);
println!("run_lobby 3");
for i in 0..4 { for i in 0..4 {
println!("run_lobby attempt stop #{}", i);
let mut r2 = mrs.join(room_id.clone()).unwrap(); let mut r2 = mrs.join(room_id.clone()).unwrap();
r2.send(format!(r#"{{ r2.send(format!(r#"{{
"msgtype": "m.text", "msgtype": "m.text",
@ -160,7 +165,6 @@ mod tests {
init(); init();
let mut mrs = MockRooms::new(); let mut mrs = MockRooms::new();
let r1 = mrs.create(); let r1 = mrs.create();
let room_id = r1.room_id();
let mut gm = GameMaster::new(r1); let mut gm = GameMaster::new(r1);
assert!(gm.run_game_setup().is_ok()); assert!(gm.run_game_setup().is_ok());
} }

View File

@ -4,6 +4,7 @@ use super::super::super::config;
use std::collections::HashMap; use std::collections::HashMap;
#[derive(Clone, Debug)]
pub struct Lobby { pub struct Lobby {
pub players: HashMap<String, Player>, pub players: HashMap<String, Player>,
pub locked: bool, pub locked: bool,
@ -36,10 +37,10 @@ impl Lobby {
self.locked = true; self.locked = true;
} }
pub fn ready(&self) -> Result<usize, &str> { pub fn ready(&self) -> Result<usize, String> {
let n: usize = self.players.len(); let n: usize = self.players.len();
if n < config::MIN_PLAYERS { if n < config::MIN_PLAYERS {
return Err("not enough players"); return Err("not enough players".to_string());
} }
Ok(n) Ok(n)
} }

View File

@ -1,4 +1,4 @@
//pub mod gamemaster; pub mod gamemaster;
pub mod player; pub mod player;
pub mod role; pub mod role;
pub mod lobby; pub mod lobby;

View File

@ -163,7 +163,7 @@ mod tests {
sinces.push(r.send("0".to_string()).ok().unwrap()); sinces.push(r.send("0".to_string()).ok().unwrap());
sinces.push(r.send("0".to_string()).ok().unwrap()); sinces.push(r.send("0".to_string()).ok().unwrap());
r.sync(); r.sync();
assert!(r.since == sinces[sinces.len()-1]); assert!(r.since == *sinces.last().unwrap());
} }
} }
@ -175,7 +175,7 @@ mod tests {
for _ in 0..10 { for _ in 0..10 {
sinces.push(r.send("0".to_string()).ok().unwrap()); sinces.push(r.send("0".to_string()).ok().unwrap());
r.sync(); r.sync();
assert!(r.since == sinces[sinces.len()-1]); assert!(r.since == *sinces.last().unwrap());
} }
} }
@ -186,9 +186,9 @@ mod tests {
let mut sinces = vec![]; let mut sinces = vec![];
sinces.push(r.send("0".to_string()).ok().unwrap()); sinces.push(r.send("0".to_string()).ok().unwrap());
assert!(r.sync().len() == 1); assert!(r.sync().len() == 1);
assert!(r.since == sinces[sinces.len()-1], "after one send: want {:?}, got {:?}: {:?}", sinces[sinces.len()-1], r.since, sinces); assert!(r.since == *sinces.last().unwrap(), "after one send: want {:?}, got {:?}: {:?}", *sinces.last().unwrap(), r.since, sinces);
assert!(r.sync().len() == 0); assert!(r.sync().len() == 0);
assert!(r.since == sinces[sinces.len()-1], "after no send: want {:?}, got {:?}: {:?}", sinces[sinces.len()-1], r.since, sinces); assert!(r.since == *sinces.last().unwrap(), "after no send: want {:?}, got {:?}: {:?}", *sinces.last().unwrap(), r.since, sinces);
} }
#[test] #[test]