2 Commits
0.1 ... 0.2

Author SHA1 Message Date
3d243836eb auto test
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/tag Build is passing
2019-10-31 21:05:20 +01:00
38d638538b allow resumption 2019-10-31 20:54:44 +01:00
2 changed files with 66 additions and 7 deletions

31
.drone.yml Normal file
View File

@@ -0,0 +1,31 @@
kind: pipeline
name: default
steps:
- name: test
image: rust:1.38.0
commands:
- cargo test
- name: build_relase
image: rust:1.38.0
commands:
- cargo install --path . --root . -f
- tar cvzf ttt.tar.gz bin src Cargo.*
when:
event:
- tag
- name: gitea_release
image: plugins/gitea-release
settings:
api_key:
from_secret: gitea_tkn
base_url:
from_secret: gitea_url
files:
- ttt.tar.gz
checksum:
- md5
- sha512
when:
event:
- tag

View File

@@ -1,3 +1,4 @@
use std::env::args;
use std::fmt;
use std::io;
use std::io::Write;
@@ -72,7 +73,7 @@ impl FromStr for Board {
match c {
'X' | 'x' => board.0.push(State::X),
'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
}
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> {
let mut winners = [State::N; 4];
let dim = self.dimension();
@@ -156,7 +167,19 @@ impl Board {
}
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();
println!("{}", &board);
let winner = loop {
@@ -204,7 +227,7 @@ fn main() {
println!("{}", &board);
}
};
println!("The winner is {}", winner);
println!("{}\nThe winner is {}", board.to_string_short(), winner);
}
#[cfg(test)]
@@ -217,10 +240,7 @@ mod test {
Board::from_str("XXX,NNN,NNN").unwrap().winner(),
Some(State::X)
);
assert_eq!(
Board::from_str("XNX,NNN,NNN").unwrap().winner(),
None
);
assert_eq!(Board::from_str("XNX,NNN,NNN").unwrap().winner(), None);
assert_eq!(
Board::from_str("NNN,XXX,NNN").unwrap().winner(),
Some(State::X)
@@ -234,4 +254,12 @@ mod test {
Some(State::O)
);
}
#[test]
fn to_string() {
assert_eq!(
&Board::from_str("XXX,NNN,NNN").unwrap().to_string_short()[..],
"XXX______"
);
}
}