i hate borrow
parent
719d197071
commit
c1160d9d7e
|
|
@ -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());
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
|
|
|
||||||
|
|
@ -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]
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue