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
use crate::{geom::Tree, math::Pos3};
impl<'a, T> Tree<'a, T> {
#[inline]
#[must_use]
pub fn find_terminal_cell(&self, pos: &Pos3) -> Option<&Self> {
if !self.boundary().contains(pos) {
return None;
}
match self {
Self::Leaf { .. } | Self::Empty { .. } => Some(self),
Self::Root { boundary, children } | Self::Branch { boundary, children } => {
let mut index = 0;
let c = boundary.centre();
if pos.x >= c.x {
index += 1;
}
if pos.y >= c.y {
index += 2;
}
if pos.z >= c.z {
index += 4;
}
children[index].find_terminal_cell(pos)
}
}
}
}