From b2c53a7cd5fd5bfeb877470a946ba305b6207d53 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 16 Nov 2022 15:41:50 +0100 Subject: [PATCH 01/12] Add `Replace` trait --- crates/fj-kernel/src/partial/mod.rs | 2 ++ crates/fj-kernel/src/partial/replace.rs | 7 +++++++ 2 files changed, 9 insertions(+) create mode 100644 crates/fj-kernel/src/partial/replace.rs diff --git a/crates/fj-kernel/src/partial/mod.rs b/crates/fj-kernel/src/partial/mod.rs index 19289522b..d9b89d44b 100644 --- a/crates/fj-kernel/src/partial/mod.rs +++ b/crates/fj-kernel/src/partial/mod.rs @@ -37,6 +37,7 @@ mod maybe_partial; mod merge; mod objects; +mod replace; mod traits; pub use self::{ @@ -50,5 +51,6 @@ pub use self::{ surface::PartialSurface, vertex::{PartialGlobalVertex, PartialSurfaceVertex, PartialVertex}, }, + replace::Replace, traits::{HasPartial, Partial}, }; diff --git a/crates/fj-kernel/src/partial/replace.rs b/crates/fj-kernel/src/partial/replace.rs new file mode 100644 index 000000000..2cfae36da --- /dev/null +++ b/crates/fj-kernel/src/partial/replace.rs @@ -0,0 +1,7 @@ +use crate::storage::Handle; + +/// Recursively replace a (partial) object referenced by another partial object +pub trait Replace { + /// Recursively replace the referenced object + fn replace(&mut self, object: Handle) -> &mut Self; +} From 3c9ebb8b73ff914fcb53aaf445538afdaf45c1e8 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 16 Nov 2022 15:42:15 +0100 Subject: [PATCH 02/12] Implement `Replace` for arrays --- crates/fj-kernel/src/partial/replace.rs | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/crates/fj-kernel/src/partial/replace.rs b/crates/fj-kernel/src/partial/replace.rs index 2cfae36da..180729979 100644 --- a/crates/fj-kernel/src/partial/replace.rs +++ b/crates/fj-kernel/src/partial/replace.rs @@ -5,3 +5,16 @@ pub trait Replace { /// Recursively replace the referenced object fn replace(&mut self, object: Handle) -> &mut Self; } + +impl Replace for [R; N] +where + R: Replace, +{ + fn replace(&mut self, object: Handle) -> &mut Self { + for item in self.iter_mut() { + item.replace(object.clone()); + } + + self + } +} From 945d55f9041b8da2ff013a46312423071037ae2d Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 16 Nov 2022 12:56:53 +0100 Subject: [PATCH 03/12] Implement `Replace` for `MaybePartial` --- crates/fj-kernel/src/partial/maybe_partial.rs | 26 ++++++++++++++++++- 1 file changed, 25 insertions(+), 1 deletion(-) diff --git a/crates/fj-kernel/src/partial/maybe_partial.rs b/crates/fj-kernel/src/partial/maybe_partial.rs index dc5c32108..3c1b71c69 100644 --- a/crates/fj-kernel/src/partial/maybe_partial.rs +++ b/crates/fj-kernel/src/partial/maybe_partial.rs @@ -2,6 +2,7 @@ use fj_math::Point; use crate::{ geometry::{path::SurfacePath, surface::SurfaceGeometry}, + get::Get, insert::Insert, objects::{ Curve, GlobalCurve, GlobalEdge, GlobalVertex, HalfEdge, Objects, @@ -11,7 +12,7 @@ use crate::{ validate::{Validate, ValidationError}, }; -use super::{HasPartial, MergeWith, Partial}; +use super::{HasPartial, MergeWith, Partial, Replace}; /// Can be used everywhere either a partial or full objects are accepted /// @@ -125,6 +126,29 @@ where } } +impl Replace for MaybePartial +where + T: HasPartial + Get, + T::Partial: Replace, +{ + fn replace(&mut self, object: Handle) -> &mut Self { + match self { + Self::Full(full) => { + if full.get().id() != object.id() { + let mut partial = full.to_partial(); + partial.replace(object); + *self = Self::Partial(partial); + } + } + Self::Partial(partial) => { + partial.replace(object); + } + } + + self + } +} + impl From> for MaybePartial where T: HasPartial, From 26c84e834264bb31d777ccb911efa0d312d3c58a Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 16 Nov 2022 12:29:33 +0100 Subject: [PATCH 04/12] Implement `Replace` for `PartialCurve` --- crates/fj-kernel/src/partial/objects/curve.rs | 9 ++++++++- crates/fj-kernel/src/partial/objects/edge.rs | 6 +++--- 2 files changed, 11 insertions(+), 4 deletions(-) diff --git a/crates/fj-kernel/src/partial/objects/curve.rs b/crates/fj-kernel/src/partial/objects/curve.rs index 0608dbd2e..a1d4cea00 100644 --- a/crates/fj-kernel/src/partial/objects/curve.rs +++ b/crates/fj-kernel/src/partial/objects/curve.rs @@ -1,7 +1,7 @@ use crate::{ geometry::path::SurfacePath, objects::{Curve, GlobalCurve, Objects, Surface}, - partial::{MaybePartial, MergeWith}, + partial::{MaybePartial, MergeWith, Replace}, storage::Handle, validate::ValidationError, }; @@ -46,6 +46,13 @@ impl MergeWith for PartialCurve { } } +impl Replace for PartialCurve { + fn replace(&mut self, surface: Handle) -> &mut Self { + self.surface = Some(surface); + self + } +} + impl From<&Curve> for PartialCurve { fn from(curve: &Curve) -> Self { Self { diff --git a/crates/fj-kernel/src/partial/objects/edge.rs b/crates/fj-kernel/src/partial/objects/edge.rs index 6a44d916d..f3fb5c70f 100644 --- a/crates/fj-kernel/src/partial/objects/edge.rs +++ b/crates/fj-kernel/src/partial/objects/edge.rs @@ -6,7 +6,7 @@ use crate::{ Curve, GlobalCurve, GlobalEdge, GlobalVertex, HalfEdge, Objects, Surface, Vertex, }, - partial::{MaybePartial, MergeWith, PartialCurve, PartialVertex}, + partial::{MaybePartial, MergeWith, PartialCurve, PartialVertex, Replace}, storage::Handle, validate::ValidationError, }; @@ -29,8 +29,8 @@ pub struct PartialHalfEdge { impl PartialHalfEdge { /// Update the partial half-edge with the given surface pub fn with_surface(mut self, surface: Handle) -> Self { - self.curve = self.curve.update_partial(|mut curve| { - curve.surface = Some(surface.clone()); + self.curve = self.curve.clone().update_partial(|mut curve| { + curve.replace(surface.clone()); curve }); From 3317f26ccb8dc445b92690ddad9488cc995e7b08 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 16 Nov 2022 12:32:16 +0100 Subject: [PATCH 05/12] Impl `Replace` for `PartialSurfaceVertex` --- crates/fj-kernel/src/partial/objects/edge.rs | 2 +- crates/fj-kernel/src/partial/objects/vertex.rs | 9 ++++++++- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/crates/fj-kernel/src/partial/objects/edge.rs b/crates/fj-kernel/src/partial/objects/edge.rs index f3fb5c70f..0b209c75f 100644 --- a/crates/fj-kernel/src/partial/objects/edge.rs +++ b/crates/fj-kernel/src/partial/objects/edge.rs @@ -38,7 +38,7 @@ impl PartialHalfEdge { vertex.update_partial(|mut vertex| { let surface_form = vertex.surface_form.clone().update_partial( |mut surface_vertex| { - surface_vertex.surface = Some(surface.clone()); + surface_vertex.replace(surface.clone()); surface_vertex }, ); diff --git a/crates/fj-kernel/src/partial/objects/vertex.rs b/crates/fj-kernel/src/partial/objects/vertex.rs index 75b6c7539..2cc9869a8 100644 --- a/crates/fj-kernel/src/partial/objects/vertex.rs +++ b/crates/fj-kernel/src/partial/objects/vertex.rs @@ -3,7 +3,7 @@ use fj_math::Point; use crate::{ builder::GlobalVertexBuilder, objects::{Curve, GlobalVertex, Objects, Surface, SurfaceVertex, Vertex}, - partial::{MaybePartial, MergeWith}, + partial::{MaybePartial, MergeWith, Replace}, storage::Handle, validate::ValidationError, }; @@ -129,6 +129,13 @@ impl MergeWith for PartialSurfaceVertex { } } +impl Replace for PartialSurfaceVertex { + fn replace(&mut self, surface: Handle) -> &mut Self { + self.surface = Some(surface); + self + } +} + impl From<&SurfaceVertex> for PartialSurfaceVertex { fn from(surface_vertex: &SurfaceVertex) -> Self { Self { From 8d45e629442cec07e4d85343aec5a187f988e008 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 16 Nov 2022 12:28:09 +0100 Subject: [PATCH 06/12] Take `&mut self` in `PartialHalfEdge` method --- crates/fj-kernel/src/algorithms/sweep/edge.rs | 84 +++++++++++-------- crates/fj-kernel/src/builder/edge.rs | 7 +- crates/fj-kernel/src/partial/objects/cycle.rs | 8 +- crates/fj-kernel/src/partial/objects/edge.rs | 4 +- crates/fj-operations/src/sketch.rs | 13 +-- 5 files changed, 68 insertions(+), 48 deletions(-) diff --git a/crates/fj-kernel/src/algorithms/sweep/edge.rs b/crates/fj-kernel/src/algorithms/sweep/edge.rs index 3d1489d24..ead3442b7 100644 --- a/crates/fj-kernel/src/algorithms/sweep/edge.rs +++ b/crates/fj-kernel/src/algorithms/sweep/edge.rs @@ -228,26 +228,34 @@ mod tests { ) .build(&objects)? .insert(&objects)?; - let side_up = HalfEdge::partial() - .with_surface(surface.clone()) - .with_back_vertex(PartialVertex { - surface_form: bottom.front().surface_form().clone().into(), - ..Default::default() - }) - .with_front_vertex(PartialVertex { - surface_form: PartialSurfaceVertex { - position: Some([1., 1.].into()), + let side_up = { + let mut side_up = HalfEdge::partial(); + side_up.with_surface(surface.clone()); + side_up + .with_back_vertex(PartialVertex { + surface_form: bottom + .front() + .surface_form() + .clone() + .into(), ..Default::default() - } - .into(), - ..Default::default() - }) - .update_as_line_segment() - .build(&objects)? - .insert(&objects)?; - let top = HalfEdge::partial() - .with_surface(surface.clone()) - .with_back_vertex(PartialVertex { + }) + .with_front_vertex(PartialVertex { + surface_form: PartialSurfaceVertex { + position: Some([1., 1.].into()), + ..Default::default() + } + .into(), + ..Default::default() + }) + .update_as_line_segment() + .build(&objects)? + .insert(&objects)? + }; + let top = { + let mut top = HalfEdge::partial(); + top.with_surface(surface.clone()); + top.with_back_vertex(PartialVertex { surface_form: PartialSurfaceVertex { position: Some([0., 1.].into()), ..Default::default() @@ -262,21 +270,29 @@ mod tests { .update_as_line_segment() .build(&objects)? .insert(&objects)? - .reverse(&objects)?; - let side_down = HalfEdge::partial() - .with_surface(surface) - .with_back_vertex(PartialVertex { - surface_form: bottom.back().surface_form().clone().into(), - ..Default::default() - }) - .with_front_vertex(PartialVertex { - surface_form: top.front().surface_form().clone().into(), - ..Default::default() - }) - .update_as_line_segment() - .build(&objects)? - .insert(&objects)? - .reverse(&objects)?; + .reverse(&objects)? + }; + let side_down = { + let mut side_down = HalfEdge::partial(); + side_down.with_surface(surface); + side_down + .with_back_vertex(PartialVertex { + surface_form: bottom + .back() + .surface_form() + .clone() + .into(), + ..Default::default() + }) + .with_front_vertex(PartialVertex { + surface_form: top.front().surface_form().clone().into(), + ..Default::default() + }) + .update_as_line_segment() + .build(&objects)? + .insert(&objects)? + .reverse(&objects)? + }; let cycle = objects .cycles diff --git a/crates/fj-kernel/src/builder/edge.rs b/crates/fj-kernel/src/builder/edge.rs index f336ed587..f5799a3ca 100644 --- a/crates/fj-kernel/src/builder/edge.rs +++ b/crates/fj-kernel/src/builder/edge.rs @@ -94,7 +94,7 @@ impl HalfEdgeBuilder for PartialHalfEdge { } fn update_as_line_segment_from_points( - self, + mut self, surface: Handle, points: [impl Into>; 2], ) -> Self { @@ -111,9 +111,8 @@ impl HalfEdgeBuilder for PartialHalfEdge { } }); - self.with_surface(surface) - .with_vertices(vertices) - .update_as_line_segment() + self.with_surface(surface); + self.with_vertices(vertices).update_as_line_segment() } fn update_as_line_segment(self) -> Self { diff --git a/crates/fj-kernel/src/partial/objects/cycle.rs b/crates/fj-kernel/src/partial/objects/cycle.rs index eedf39ff8..449f7ae12 100644 --- a/crates/fj-kernel/src/partial/objects/cycle.rs +++ b/crates/fj-kernel/src/partial/objects/cycle.rs @@ -56,9 +56,11 @@ impl PartialCycle { pub fn with_surface(mut self, surface: Option>) -> Self { if let Some(surface) = surface { for half_edge in &mut self.half_edges { - *half_edge = half_edge.clone().update_partial(|half_edge| { - half_edge.with_surface(surface.clone()) - }); + *half_edge = + half_edge.clone().update_partial(|mut half_edge| { + half_edge.with_surface(surface.clone()); + half_edge + }); } } self diff --git a/crates/fj-kernel/src/partial/objects/edge.rs b/crates/fj-kernel/src/partial/objects/edge.rs index 0b209c75f..be1b4f42b 100644 --- a/crates/fj-kernel/src/partial/objects/edge.rs +++ b/crates/fj-kernel/src/partial/objects/edge.rs @@ -28,13 +28,13 @@ pub struct PartialHalfEdge { impl PartialHalfEdge { /// Update the partial half-edge with the given surface - pub fn with_surface(mut self, surface: Handle) -> Self { + pub fn with_surface(&mut self, surface: Handle) -> &mut Self { self.curve = self.curve.clone().update_partial(|mut curve| { curve.replace(surface.clone()); curve }); - self.vertices = self.vertices.map(|vertex| { + self.vertices = self.vertices.clone().map(|vertex| { vertex.update_partial(|mut vertex| { let surface_form = vertex.surface_form.clone().update_partial( |mut surface_vertex| { diff --git a/crates/fj-operations/src/sketch.rs b/crates/fj-operations/src/sketch.rs index 90e596d2f..f7303953c 100644 --- a/crates/fj-operations/src/sketch.rs +++ b/crates/fj-operations/src/sketch.rs @@ -27,11 +27,14 @@ impl Shape for fj::Sketch { // Circles have just a single round edge with no vertices. So // none need to be added here. - let half_edge = HalfEdge::partial() - .with_surface(surface) - .update_as_circle_from_radius(circle.radius(), objects)? - .build(objects)? - .insert(objects)?; + let half_edge = { + let mut half_edge = HalfEdge::partial(); + half_edge.with_surface(surface); + half_edge + .update_as_circle_from_radius(circle.radius(), objects)? + .build(objects)? + .insert(objects)? + }; let cycle = objects.cycles.insert(Cycle::new([half_edge]))?; Face::partial() From e0690d57af691f4a707e4e31f73733894e4ff293 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 16 Nov 2022 15:45:09 +0100 Subject: [PATCH 07/12] Implement `Replace` for `PartialHalfEdge` --- crates/fj-kernel/src/algorithms/sweep/edge.rs | 8 +-- crates/fj-kernel/src/builder/edge.rs | 4 +- crates/fj-kernel/src/partial/objects/cycle.rs | 6 ++- crates/fj-kernel/src/partial/objects/edge.rs | 49 ++++++++++--------- crates/fj-operations/src/sketch.rs | 4 +- 5 files changed, 37 insertions(+), 34 deletions(-) diff --git a/crates/fj-kernel/src/algorithms/sweep/edge.rs b/crates/fj-kernel/src/algorithms/sweep/edge.rs index ead3442b7..574ead631 100644 --- a/crates/fj-kernel/src/algorithms/sweep/edge.rs +++ b/crates/fj-kernel/src/algorithms/sweep/edge.rs @@ -200,7 +200,7 @@ mod tests { builder::HalfEdgeBuilder, insert::Insert, objects::{Cycle, Face, HalfEdge, Objects}, - partial::{HasPartial, PartialSurfaceVertex, PartialVertex}, + partial::{HasPartial, PartialSurfaceVertex, PartialVertex, Replace}, }; #[test] @@ -230,7 +230,7 @@ mod tests { .insert(&objects)?; let side_up = { let mut side_up = HalfEdge::partial(); - side_up.with_surface(surface.clone()); + side_up.replace(surface.clone()); side_up .with_back_vertex(PartialVertex { surface_form: bottom @@ -254,7 +254,7 @@ mod tests { }; let top = { let mut top = HalfEdge::partial(); - top.with_surface(surface.clone()); + top.replace(surface.clone()); top.with_back_vertex(PartialVertex { surface_form: PartialSurfaceVertex { position: Some([0., 1.].into()), @@ -274,7 +274,7 @@ mod tests { }; let side_down = { let mut side_down = HalfEdge::partial(); - side_down.with_surface(surface); + side_down.replace(surface); side_down .with_back_vertex(PartialVertex { surface_form: bottom diff --git a/crates/fj-kernel/src/builder/edge.rs b/crates/fj-kernel/src/builder/edge.rs index f5799a3ca..ad24ac9b2 100644 --- a/crates/fj-kernel/src/builder/edge.rs +++ b/crates/fj-kernel/src/builder/edge.rs @@ -6,7 +6,7 @@ use crate::{ objects::{Curve, Objects, Surface, Vertex, VerticesInNormalizedOrder}, partial::{ MaybePartial, MergeWith, PartialGlobalEdge, PartialHalfEdge, - PartialSurfaceVertex, PartialVertex, + PartialSurfaceVertex, PartialVertex, Replace, }, storage::Handle, validate::ValidationError, @@ -111,7 +111,7 @@ impl HalfEdgeBuilder for PartialHalfEdge { } }); - self.with_surface(surface); + self.replace(surface); self.with_vertices(vertices).update_as_line_segment() } diff --git a/crates/fj-kernel/src/partial/objects/cycle.rs b/crates/fj-kernel/src/partial/objects/cycle.rs index 449f7ae12..e3fd458a3 100644 --- a/crates/fj-kernel/src/partial/objects/cycle.rs +++ b/crates/fj-kernel/src/partial/objects/cycle.rs @@ -1,7 +1,9 @@ use crate::{ builder::HalfEdgeBuilder, objects::{Cycle, HalfEdge, Objects, Surface}, - partial::{MaybePartial, MergeWith, PartialHalfEdge, PartialVertex}, + partial::{ + MaybePartial, MergeWith, PartialHalfEdge, PartialVertex, Replace, + }, storage::Handle, validate::ValidationError, }; @@ -58,7 +60,7 @@ impl PartialCycle { for half_edge in &mut self.half_edges { *half_edge = half_edge.clone().update_partial(|mut half_edge| { - half_edge.with_surface(surface.clone()); + half_edge.replace(surface.clone()); half_edge }); } diff --git a/crates/fj-kernel/src/partial/objects/edge.rs b/crates/fj-kernel/src/partial/objects/edge.rs index be1b4f42b..ef6e94b4b 100644 --- a/crates/fj-kernel/src/partial/objects/edge.rs +++ b/crates/fj-kernel/src/partial/objects/edge.rs @@ -27,30 +27,6 @@ pub struct PartialHalfEdge { } impl PartialHalfEdge { - /// Update the partial half-edge with the given surface - pub fn with_surface(&mut self, surface: Handle) -> &mut Self { - self.curve = self.curve.clone().update_partial(|mut curve| { - curve.replace(surface.clone()); - curve - }); - - self.vertices = self.vertices.clone().map(|vertex| { - vertex.update_partial(|mut vertex| { - let surface_form = vertex.surface_form.clone().update_partial( - |mut surface_vertex| { - surface_vertex.replace(surface.clone()); - surface_vertex - }, - ); - - vertex.surface_form = surface_form; - vertex - }) - }); - - self - } - /// Update the partial half-edge with the given curve pub fn with_curve(mut self, curve: impl Into>) -> Self { self.curve = curve.into(); @@ -127,6 +103,31 @@ impl MergeWith for PartialHalfEdge { } } +impl Replace for PartialHalfEdge { + fn replace(&mut self, surface: Handle) -> &mut Self { + self.curve = self.curve.clone().update_partial(|mut curve| { + curve.replace(surface.clone()); + curve + }); + + self.vertices = self.vertices.clone().map(|vertex| { + vertex.update_partial(|mut vertex| { + let surface_form = vertex.surface_form.clone().update_partial( + |mut surface_vertex| { + surface_vertex.replace(surface.clone()); + surface_vertex + }, + ); + + vertex.surface_form = surface_form; + vertex + }) + }); + + self + } +} + impl From<&HalfEdge> for PartialHalfEdge { fn from(half_edge: &HalfEdge) -> Self { let [back_vertex, front_vertex] = diff --git a/crates/fj-operations/src/sketch.rs b/crates/fj-operations/src/sketch.rs index f7303953c..377c79f7c 100644 --- a/crates/fj-operations/src/sketch.rs +++ b/crates/fj-operations/src/sketch.rs @@ -5,7 +5,7 @@ use fj_kernel::{ builder::{FaceBuilder, HalfEdgeBuilder}, insert::Insert, objects::{Cycle, Face, HalfEdge, Objects, Sketch}, - partial::HasPartial, + partial::{HasPartial, Replace}, validate::ValidationError, }; use fj_math::{Aabb, Point}; @@ -29,7 +29,7 @@ impl Shape for fj::Sketch { let half_edge = { let mut half_edge = HalfEdge::partial(); - half_edge.with_surface(surface); + half_edge.replace(surface); half_edge .update_as_circle_from_radius(circle.radius(), objects)? .build(objects)? From 9c472e114aebc5ea5072654336fb8ca6a4654493 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 16 Nov 2022 13:00:18 +0100 Subject: [PATCH 08/12] Fully replace surface in curve --- crates/fj-kernel/src/partial/objects/edge.rs | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/crates/fj-kernel/src/partial/objects/edge.rs b/crates/fj-kernel/src/partial/objects/edge.rs index ef6e94b4b..c09b89d70 100644 --- a/crates/fj-kernel/src/partial/objects/edge.rs +++ b/crates/fj-kernel/src/partial/objects/edge.rs @@ -105,10 +105,7 @@ impl MergeWith for PartialHalfEdge { impl Replace for PartialHalfEdge { fn replace(&mut self, surface: Handle) -> &mut Self { - self.curve = self.curve.clone().update_partial(|mut curve| { - curve.replace(surface.clone()); - curve - }); + self.curve.replace(surface.clone()); self.vertices = self.vertices.clone().map(|vertex| { vertex.update_partial(|mut vertex| { From 816197f3c721bc5f65cd2600097c2140d08e4426 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 16 Nov 2022 13:03:14 +0100 Subject: [PATCH 09/12] Fully replace surface in surface vertex --- crates/fj-kernel/src/partial/objects/edge.rs | 9 +-------- 1 file changed, 1 insertion(+), 8 deletions(-) diff --git a/crates/fj-kernel/src/partial/objects/edge.rs b/crates/fj-kernel/src/partial/objects/edge.rs index c09b89d70..0a1e57845 100644 --- a/crates/fj-kernel/src/partial/objects/edge.rs +++ b/crates/fj-kernel/src/partial/objects/edge.rs @@ -109,14 +109,7 @@ impl Replace for PartialHalfEdge { self.vertices = self.vertices.clone().map(|vertex| { vertex.update_partial(|mut vertex| { - let surface_form = vertex.surface_form.clone().update_partial( - |mut surface_vertex| { - surface_vertex.replace(surface.clone()); - surface_vertex - }, - ); - - vertex.surface_form = surface_form; + vertex.surface_form.replace(surface.clone()); vertex }) }); From 69c516012507232be59e225bf0b55fa688e0109f Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 16 Nov 2022 13:05:07 +0100 Subject: [PATCH 10/12] Implement `Replace` for `PartialVertex` --- crates/fj-kernel/src/partial/objects/edge.rs | 2 +- crates/fj-kernel/src/partial/objects/vertex.rs | 7 +++++++ 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/crates/fj-kernel/src/partial/objects/edge.rs b/crates/fj-kernel/src/partial/objects/edge.rs index 0a1e57845..9167daf0e 100644 --- a/crates/fj-kernel/src/partial/objects/edge.rs +++ b/crates/fj-kernel/src/partial/objects/edge.rs @@ -109,7 +109,7 @@ impl Replace for PartialHalfEdge { self.vertices = self.vertices.clone().map(|vertex| { vertex.update_partial(|mut vertex| { - vertex.surface_form.replace(surface.clone()); + vertex.replace(surface.clone()); vertex }) }); diff --git a/crates/fj-kernel/src/partial/objects/vertex.rs b/crates/fj-kernel/src/partial/objects/vertex.rs index 2cc9869a8..418917287 100644 --- a/crates/fj-kernel/src/partial/objects/vertex.rs +++ b/crates/fj-kernel/src/partial/objects/vertex.rs @@ -67,6 +67,13 @@ impl MergeWith for PartialVertex { } } +impl Replace for PartialVertex { + fn replace(&mut self, surface: Handle) -> &mut Self { + self.surface_form.replace(surface); + self + } +} + impl From<&Vertex> for PartialVertex { fn from(vertex: &Vertex) -> Self { Self { From 31f3304c2544ab7111a60598f36cb6c5fbb692e8 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 16 Nov 2022 13:07:55 +0100 Subject: [PATCH 11/12] Fully replace surface in vertex --- crates/fj-kernel/src/partial/objects/edge.rs | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/crates/fj-kernel/src/partial/objects/edge.rs b/crates/fj-kernel/src/partial/objects/edge.rs index 9167daf0e..5dc757848 100644 --- a/crates/fj-kernel/src/partial/objects/edge.rs +++ b/crates/fj-kernel/src/partial/objects/edge.rs @@ -107,11 +107,9 @@ impl Replace for PartialHalfEdge { fn replace(&mut self, surface: Handle) -> &mut Self { self.curve.replace(surface.clone()); - self.vertices = self.vertices.clone().map(|vertex| { - vertex.update_partial(|mut vertex| { - vertex.replace(surface.clone()); - vertex - }) + self.vertices = self.vertices.clone().map(|mut vertex| { + vertex.replace(surface.clone()); + vertex }); self From 6622fd3437979144d9ffef3e36eb2ac9532a8e2e Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 16 Nov 2022 13:08:32 +0100 Subject: [PATCH 12/12] Refactor --- crates/fj-kernel/src/partial/objects/edge.rs | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/crates/fj-kernel/src/partial/objects/edge.rs b/crates/fj-kernel/src/partial/objects/edge.rs index 5dc757848..50633d4be 100644 --- a/crates/fj-kernel/src/partial/objects/edge.rs +++ b/crates/fj-kernel/src/partial/objects/edge.rs @@ -107,10 +107,9 @@ impl Replace for PartialHalfEdge { fn replace(&mut self, surface: Handle) -> &mut Self { self.curve.replace(surface.clone()); - self.vertices = self.vertices.clone().map(|mut vertex| { + for vertex in &mut self.vertices { vertex.replace(surface.clone()); - vertex - }); + } self }