use crate::{
objects::{Cycle, HalfEdge},
storage::Handle,
};
pub trait UpdateCycle {
fn add_half_edges(
&self,
half_edges: impl IntoIterator<Item = Handle<HalfEdge>>,
) -> Cycle;
fn replace_half_edge(
&self,
original: &Handle<HalfEdge>,
replacement: Handle<HalfEdge>,
) -> Cycle;
fn update_nth_half_edge(
&self,
index: usize,
f: impl FnMut(&Handle<HalfEdge>) -> Handle<HalfEdge>,
) -> Cycle;
}
impl UpdateCycle for Cycle {
fn add_half_edges(
&self,
half_edges: impl IntoIterator<Item = Handle<HalfEdge>>,
) -> Cycle {
let half_edges = self.half_edges().cloned().chain(half_edges);
Cycle::new(half_edges)
}
fn replace_half_edge(
&self,
original: &Handle<HalfEdge>,
replacement: Handle<HalfEdge>,
) -> Cycle {
let mut num_replacements = 0;
let half_edges = self.half_edges().map(|half_edge| {
if half_edge.id() == original.id() {
num_replacements += 1;
replacement.clone()
} else {
half_edge.clone()
}
});
let cycle = Cycle::new(half_edges);
assert_eq!(
num_replacements, 1,
"Expected operation to replace exactly one half-edge"
);
cycle
}
fn update_nth_half_edge(
&self,
index: usize,
mut f: impl FnMut(&Handle<HalfEdge>) -> Handle<HalfEdge>,
) -> Cycle {
let mut num_replacements = 0;
let half_edges = self.half_edges().enumerate().map(|(i, half_edge)| {
if i == index {
num_replacements += 1;
f(half_edge)
} else {
half_edge.clone()
}
});
let cycle = Cycle::new(half_edges);
assert_eq!(
num_replacements, 1,
"Expected operation to replace exactly one half-edge"
);
cycle
}
}