Compare commits
2 Commits
2d6a15510e
...
5bee972d2f
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5bee972d2f | ||
|
|
4b643ed750 |
@@ -4,8 +4,6 @@ use std::fs::File;
|
|||||||
use std::io::{BufReader, prelude::*};
|
use std::io::{BufReader, prelude::*};
|
||||||
use std::num;
|
use std::num;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct Crossword {
|
pub struct Crossword {
|
||||||
data: Vec<Vec<char>>,
|
data: Vec<Vec<char>>,
|
||||||
@@ -24,7 +22,6 @@ impl<'a> WordPuller<'a> {
|
|||||||
pub fn take(&self, num_of_letters: usize) -> String {
|
pub fn take(&self, num_of_letters: usize) -> String {
|
||||||
let mut word = String::new();
|
let mut word = String::new();
|
||||||
|
|
||||||
|
|
||||||
for i in 0..num_of_letters {
|
for i in 0..num_of_letters {
|
||||||
let x = self.x as isize + (i as isize * self.direction.0);
|
let x = self.x as isize + (i as isize * self.direction.0);
|
||||||
let y = self.y as isize + (i as isize * self.direction.1);
|
let y = self.y as isize + (i as isize * self.direction.1);
|
||||||
@@ -70,14 +67,70 @@ impl Crossword {
|
|||||||
self.height
|
self.height
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn n(&self, x: usize, y: usize) -> WordPuller { WordPuller {x, y, direction:(-1, 0), crossword: self}}
|
pub fn n(&self, x: usize, y: usize) -> WordPuller {
|
||||||
pub fn ne(&self, x: usize, y: usize) -> WordPuller { WordPuller {x, y, direction:(-1, 1), crossword: self}}
|
WordPuller {
|
||||||
pub fn e(&self, x: usize, y: usize) -> WordPuller { WordPuller {x, y, direction:(0, 1), crossword: self}}
|
x,
|
||||||
pub fn se(&self, x: usize, y: usize) -> WordPuller { WordPuller {x, y, direction:(1, 1), crossword: self}}
|
y,
|
||||||
pub fn s(&self, x: usize, y: usize) -> WordPuller { WordPuller {x, y, direction:(1, 0), crossword: self}}
|
direction: (-1, 0),
|
||||||
pub fn sw(&self, x: usize, y: usize) -> WordPuller { WordPuller {x, y, direction:(1, -1), crossword: self}}
|
crossword: self,
|
||||||
pub fn w(&self, x: usize, y: usize) -> WordPuller { WordPuller {x, y, direction:(0, -1), crossword: self}}
|
}
|
||||||
pub fn nw(&self, x: usize, y: usize) -> WordPuller { WordPuller {x, y, direction:(-1, -1), crossword: self}}
|
}
|
||||||
|
pub fn ne(&self, x: usize, y: usize) -> WordPuller {
|
||||||
|
WordPuller {
|
||||||
|
x,
|
||||||
|
y,
|
||||||
|
direction: (-1, 1),
|
||||||
|
crossword: self,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn e(&self, x: usize, y: usize) -> WordPuller {
|
||||||
|
WordPuller {
|
||||||
|
x,
|
||||||
|
y,
|
||||||
|
direction: (0, 1),
|
||||||
|
crossword: self,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn se(&self, x: usize, y: usize) -> WordPuller {
|
||||||
|
WordPuller {
|
||||||
|
x,
|
||||||
|
y,
|
||||||
|
direction: (1, 1),
|
||||||
|
crossword: self,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn s(&self, x: usize, y: usize) -> WordPuller {
|
||||||
|
WordPuller {
|
||||||
|
x,
|
||||||
|
y,
|
||||||
|
direction: (1, 0),
|
||||||
|
crossword: self,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn sw(&self, x: usize, y: usize) -> WordPuller {
|
||||||
|
WordPuller {
|
||||||
|
x,
|
||||||
|
y,
|
||||||
|
direction: (1, -1),
|
||||||
|
crossword: self,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn w(&self, x: usize, y: usize) -> WordPuller {
|
||||||
|
WordPuller {
|
||||||
|
x,
|
||||||
|
y,
|
||||||
|
direction: (0, -1),
|
||||||
|
crossword: self,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn nw(&self, x: usize, y: usize) -> WordPuller {
|
||||||
|
WordPuller {
|
||||||
|
x,
|
||||||
|
y,
|
||||||
|
direction: (-1, -1),
|
||||||
|
crossword: self,
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Display for Crossword {
|
impl Display for Crossword {
|
||||||
|
|||||||
Reference in New Issue
Block a user