From 4ed2d71e76f04c75a214e43363dc1b64e109fe3d Mon Sep 17 00:00:00 2001 From: troido Date: Fri, 21 Feb 2020 19:22:26 +0100 Subject: used rank in taking objects --- src/controls.rs | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) (limited to 'src/controls.rs') diff --git a/src/controls.rs b/src/controls.rs index a27348d..b944a93 100644 --- a/src/controls.rs +++ b/src/controls.rs @@ -42,24 +42,24 @@ impl Direction { #[derive(Debug, Clone)] pub enum Control { Move(Direction), - Take(u64), - Drop(u64) + Take(Option), + Drop(usize) } impl Control { pub fn from_json(val: &Value) -> Option{ - if let Value::String(control_type) = &val[0] { + if let Value::String(control_type) = val.get(0)? { match control_type.as_str() { - "move" => match Direction::from_json(&val[1]) { + "move" => match Direction::from_json(val.get(1)?) { Some(dir) => Some(Control::Move(dir)), None => None }, - "take" => Some(Control::Take(0)), /*match val[1].as_u64() { + "take" => Some(Control::Take(val.get(1)?.as_u64())), /*match val[1].as_u64() { Some(rank) => Some(Control::Take(rank)), _ => None }*/ - "drop" => Some(Control::Drop(0)), + "drop" => Some(Control::Drop(val.get(1)?.as_u64().unwrap_or(0) as usize)), _ => None } } else {None} -- cgit