mirror of
https://github.com/hannobraun/Fornjot
synced 2025-01-15 04:37:47 +00:00
Merge pull request #1222 from hannobraun/duplication
Fix another object duplication issue
This commit is contained in:
commit
2ff3275d01
@ -105,6 +105,28 @@ impl MaybePartial<GlobalEdge> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl MaybePartial<HalfEdge> {
|
impl MaybePartial<HalfEdge> {
|
||||||
|
/// Access the back vertex
|
||||||
|
pub fn back(&self) -> Option<MaybePartial<Vertex>> {
|
||||||
|
match self {
|
||||||
|
Self::Full(full) => Some(full.back().clone().into()),
|
||||||
|
Self::Partial(partial) => {
|
||||||
|
let [back, _] = &partial.vertices;
|
||||||
|
back.clone()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Access the front vertex
|
||||||
|
pub fn front(&self) -> Option<MaybePartial<Vertex>> {
|
||||||
|
match self {
|
||||||
|
Self::Full(full) => Some(full.front().clone().into()),
|
||||||
|
Self::Partial(partial) => {
|
||||||
|
let [_, front] = &partial.vertices;
|
||||||
|
front.clone()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Access the vertices
|
/// Access the vertices
|
||||||
pub fn vertices(&self) -> [Option<MaybePartial<Vertex>>; 2] {
|
pub fn vertices(&self) -> [Option<MaybePartial<Vertex>>; 2] {
|
||||||
match self {
|
match self {
|
||||||
|
@ -160,21 +160,46 @@ impl PartialCycle {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Build a full [`Cycle`] from the partial cycle
|
/// Build a full [`Cycle`] from the partial cycle
|
||||||
pub fn build(self, objects: &Objects) -> Cycle {
|
pub fn build(mut self, objects: &Objects) -> Cycle {
|
||||||
let surface = self.surface.expect("Need surface to build `Cycle`");
|
let surface = self.surface.expect("Need surface to build `Cycle`");
|
||||||
let surface_for_edges = surface.clone();
|
let surface_for_edges = surface.clone();
|
||||||
let half_edges = {
|
let half_edges = {
|
||||||
let (half_edges, _) = self.half_edges.into_iter().fold(
|
let last_vertex = self
|
||||||
(Vec::new(), None),
|
.half_edges
|
||||||
|(mut half_edges, previous), next| {
|
.last_mut()
|
||||||
let previous_half_edge: Option<HalfEdge> = previous;
|
.and_then(|half_edge| {
|
||||||
|
half_edge.front().map(|vertex| (half_edge, vertex))
|
||||||
|
})
|
||||||
|
.and_then(|(half_edge, vertex)| {
|
||||||
|
vertex.surface_form().map(|surface_vertex| {
|
||||||
|
(half_edge, vertex, surface_vertex)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
.map(|(half_edge, vertex, surface_vertex)| {
|
||||||
|
let surface_vertex = surface_vertex
|
||||||
|
.update_partial(|surface_vertex| {
|
||||||
|
surface_vertex.with_surface(Some(surface.clone()))
|
||||||
|
})
|
||||||
|
.into_full(objects);
|
||||||
|
|
||||||
let previous_vertex = previous_half_edge.map(|half_edge| {
|
*half_edge =
|
||||||
let [_, vertex] = half_edge.vertices().clone();
|
half_edge.clone().update_partial(|half_edge| {
|
||||||
vertex.surface_form().clone()
|
half_edge.with_front_vertex(Some(
|
||||||
|
vertex.update_partial(|vertex| {
|
||||||
|
vertex.with_surface_form(Some(
|
||||||
|
surface_vertex.clone(),
|
||||||
|
))
|
||||||
|
}),
|
||||||
|
))
|
||||||
});
|
});
|
||||||
|
|
||||||
let next = next
|
surface_vertex
|
||||||
|
});
|
||||||
|
|
||||||
|
let (half_edges, _) = self.half_edges.into_iter().fold(
|
||||||
|
(Vec::new(), last_vertex),
|
||||||
|
|(mut half_edges, previous_vertex), half_edge| {
|
||||||
|
let half_edge = half_edge
|
||||||
.update_partial(|half_edge| {
|
.update_partial(|half_edge| {
|
||||||
let [from, _] = half_edge.vertices.clone();
|
let [from, _] = half_edge.vertices.clone();
|
||||||
let from = from.map(|vertex| {
|
let from = from.map(|vertex| {
|
||||||
@ -189,9 +214,10 @@ impl PartialCycle {
|
|||||||
})
|
})
|
||||||
.into_full(objects);
|
.into_full(objects);
|
||||||
|
|
||||||
half_edges.push(next.clone());
|
let front = half_edge.front().surface_form().clone();
|
||||||
|
half_edges.push(half_edge);
|
||||||
|
|
||||||
(half_edges, Some(next))
|
(half_edges, Some(front))
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user