1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
use std::collections::HashMap;
use crate::noisemap::NoiseMapGeneratorBase;
use crate::world::Size;
#[derive(Copy, Clone)]
pub enum ConstraintType {
LT(f64),
GT(f64)
}
pub struct Constraint {
nm: Box<dyn NoiseMapGeneratorBase>,
constraint: ConstraintType
}
#[macro_export]
macro_rules! constraint {
($nm:expr, < $v:expr) => (Constraint::new($nm, ConstraintType::LT($v)));
($nm:expr, > $v:expr) => (Constraint::new($nm, ConstraintType::GT($v)));
}
impl Constraint {
pub fn new(nm: Box<dyn NoiseMapGeneratorBase>, constraint: ConstraintType) -> Constraint {
Constraint {
nm,
constraint
}
}
pub fn satisfied_by(&self, x: i64, y: i64, size: Size, chunk_x: i64, chunk_y: i64, nms: &mut HashMap<u64, Vec<Vec<f64>>>) -> bool {
let id = self.nm.id();
let nm = nms.entry(id).or_insert_with(|| self.nm.generate_sized_chunk(size, chunk_x, chunk_y));
let x = (x as i64) % size.w;
let y = (y as i64) % size.h;
match self.constraint {
ConstraintType::LT(threshold) => nm[y as usize][x as usize] < threshold,
ConstraintType::GT(threshold) => nm[y as usize][x as usize] > threshold
}
}
}