From 02098f0d579259545584e246f64ed5e41be9537b Mon Sep 17 00:00:00 2001 From: stale Date: Mon, 11 Jul 2022 12:06:17 -0300 Subject: implement reveal on lose --- src/main.rs | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'src/main.rs') diff --git a/src/main.rs b/src/main.rs index ce1cd45..7a85e63 100644 --- a/src/main.rs +++ b/src/main.rs @@ -309,7 +309,7 @@ async fn empty_rooms(rooms: &RoomMap) -> Vec { } fn room_from_form(uid: RoomId, rinfo: &HashMap, conf: &Conf) -> Result<(types::Room, bool), Rejection> { - if let (Some(w),Some(h),Some(num),Some(denom),public,asfm,rborders,Some(limit)) = ( + if let (Some(w),Some(h),Some(num),Some(denom),public,asfm,rborders,revealol,Some(limit)) = ( rinfo.get("bwidth").and_then(|w| w.parse::().ok()), rinfo.get("bheight").and_then(|h| h.parse::().ok()), rinfo.get("mineratio-n").and_then(|n| n.parse::().ok()), @@ -317,12 +317,16 @@ fn room_from_form(uid: RoomId, rinfo: &HashMap, conf: &Conf) -> R rinfo.get("public").map(|s| s == "on").unwrap_or(false), rinfo.get("allsafe1move").map(|s| s == "on").unwrap_or(false), rinfo.get("rborders").map(|s| s == "on").unwrap_or(false), + rinfo.get("revealonlose").map(|s| s == "on").unwrap_or(false), rinfo.get("limit").and_then(|l| l.parse::().ok()), ) { if w.get()*h.get() > conf.limits.board_area { return Err(warp::reject::custom(BoardTooBig)) } - let board_conf = minesweeper::BoardConf { w, h, mine_ratio: (num,denom), always_safe_first_move: asfm, revealed_borders: rborders }; + let board_conf = minesweeper::BoardConf { + w, h, mine_ratio: (num,denom), + always_safe_first_move: asfm, revealed_borders: rborders, reveal_on_lose: revealol + }; let name = { let n = rinfo.get("rname").unwrap().to_owned(); if n.is_empty() { uid.to_string() } else { n } -- cgit v1.2.3