allow resumption

This commit is contained in:
shimun 2019-10-31 20:54:44 +01:00
parent 7ed65c475a
commit 38d638538b
Signed by: shimun
GPG Key ID: E81D8382DC2F971B

View File

@ -1,3 +1,4 @@
use std::env::args;
use std::fmt; use std::fmt;
use std::io; use std::io;
use std::io::Write; use std::io::Write;
@ -72,7 +73,7 @@ impl FromStr for Board {
match c { match c {
'X' | 'x' => board.0.push(State::X), 'X' | 'x' => board.0.push(State::X),
'O' | 'o' => board.0.push(State::O), 'O' | 'o' => board.0.push(State::O),
'N' | 'n' => board.0.push(State::N), 'N' | 'n' | '_' => board.0.push(State::N),
_ => (), _ => (),
} }
} }
@ -96,6 +97,16 @@ impl Board {
(self.0.len() as f64).sqrt() as usize (self.0.len() as f64).sqrt() as usize
} }
fn to_string_short(&self) -> String {
let mut s = String::with_capacity(self.0.len() + self.dimension());
for y in 0..self.dimension() {
for x in 0..self.dimension() {
s.push_str(&self[(x, y)].to_string())
}
}
s
}
fn winner(&self) -> Option<State> { fn winner(&self) -> Option<State> {
let mut winners = [State::N; 4]; let mut winners = [State::N; 4];
let dim = self.dimension(); let dim = self.dimension();
@ -156,7 +167,19 @@ impl Board {
} }
fn main() { fn main() {
let mut board = Board::default(); let mut board = {
if let Some(arg) = args().skip(1).next() {
if let Ok(size) = arg.parse::<usize>() {
Board::new(size)
} else if let Ok(board) = Board::from_str(&arg) {
board
} else {
Board::default()
}
} else {
Board::default()
}
};
let stdin = std::io::stdin(); let stdin = std::io::stdin();
println!("{}", &board); println!("{}", &board);
let winner = loop { let winner = loop {
@ -204,7 +227,7 @@ fn main() {
println!("{}", &board); println!("{}", &board);
} }
}; };
println!("The winner is {}", winner); println!("{}\nThe winner is {}", board.to_string_short(), winner);
} }
#[cfg(test)] #[cfg(test)]
@ -217,10 +240,7 @@ mod test {
Board::from_str("XXX,NNN,NNN").unwrap().winner(), Board::from_str("XXX,NNN,NNN").unwrap().winner(),
Some(State::X) Some(State::X)
); );
assert_eq!( assert_eq!(Board::from_str("XNX,NNN,NNN").unwrap().winner(), None);
Board::from_str("XNX,NNN,NNN").unwrap().winner(),
None
);
assert_eq!( assert_eq!(
Board::from_str("NNN,XXX,NNN").unwrap().winner(), Board::from_str("NNN,XXX,NNN").unwrap().winner(),
Some(State::X) Some(State::X)
@ -234,4 +254,12 @@ mod test {
Some(State::O) Some(State::O)
); );
} }
#[test]
fn to_string() {
assert_eq!(
&Board::from_str("XXX,NNN,NNN").unwrap().to_string_short()[..],
"XXX______"
);
}
} }