From ebf1e934fcb9ad6c9a5b90917c81491ddb43e010 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 30 Nov 2022 13:19:27 +0100 Subject: [PATCH 01/11] Add `PartialHalfEdge::curve` --- crates/fj-kernel/src/builder/edge.rs | 6 +++--- crates/fj-kernel/src/partial/maybe_partial.rs | 2 +- crates/fj-kernel/src/partial/objects/edge.rs | 9 +++++++-- 3 files changed, 11 insertions(+), 6 deletions(-) diff --git a/crates/fj-kernel/src/builder/edge.rs b/crates/fj-kernel/src/builder/edge.rs index 3381151d3..47eba2bf2 100644 --- a/crates/fj-kernel/src/builder/edge.rs +++ b/crates/fj-kernel/src/builder/edge.rs @@ -73,7 +73,7 @@ impl HalfEdgeBuilder for PartialHalfEdge { radius: impl Into, objects: &mut Service, ) -> Self { - let mut curve = self.curve.clone().into_partial(); + let mut curve = self.curve().into_partial(); curve.update_as_circle_from_radius(radius); let path = curve.path.expect("Expected path that was just created"); @@ -133,7 +133,7 @@ impl HalfEdgeBuilder for PartialHalfEdge { [&from, &to].map(|vertex| vertex.surface_form()); let surface = self - .curve + .curve() .surface() .merge_with(from_surface.surface()) .merge_with(to_surface.surface()) @@ -144,7 +144,7 @@ impl HalfEdgeBuilder for PartialHalfEdge { .expect("Can't infer line segment without surface position") }); - let mut curve = self.curve.clone().into_partial(); + let mut curve = self.curve().into_partial(); curve.surface = Some(surface); curve.update_as_line_from_points(points); diff --git a/crates/fj-kernel/src/partial/maybe_partial.rs b/crates/fj-kernel/src/partial/maybe_partial.rs index fd17431ca..a85e51074 100644 --- a/crates/fj-kernel/src/partial/maybe_partial.rs +++ b/crates/fj-kernel/src/partial/maybe_partial.rs @@ -218,7 +218,7 @@ impl MaybePartial { pub fn curve(&self) -> MaybePartial { match self { Self::Full(full) => full.curve().clone().into(), - Self::Partial(partial) => partial.curve.clone(), + Self::Partial(partial) => partial.curve(), } } diff --git a/crates/fj-kernel/src/partial/objects/edge.rs b/crates/fj-kernel/src/partial/objects/edge.rs index 4e19b627f..e840ea672 100644 --- a/crates/fj-kernel/src/partial/objects/edge.rs +++ b/crates/fj-kernel/src/partial/objects/edge.rs @@ -25,15 +25,20 @@ pub struct PartialHalfEdge { } impl PartialHalfEdge { + /// Access the partial half-edge's curve + pub fn curve(&self) -> MaybePartial { + self.curve.clone() + } + /// Build a full [`HalfEdge`] from the partial half-edge pub fn build(mut self, objects: &mut Service) -> HalfEdge { let global_curve = self - .curve + .curve() .global_form() .merge_with(self.global_form.curve()); let curve = { - self.curve = self.curve.merge_with(PartialCurve { + self.curve = self.curve().merge_with(PartialCurve { global_form: global_curve, ..Default::default() }); From 06bc1b057339b8c9bc125d582728b1b4ed6a958e Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 30 Nov 2022 13:20:59 +0100 Subject: [PATCH 02/11] Add `MaybePartial::curve` --- crates/fj-kernel/src/partial/maybe_partial.rs | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/crates/fj-kernel/src/partial/maybe_partial.rs b/crates/fj-kernel/src/partial/maybe_partial.rs index a85e51074..2d6f9d41b 100644 --- a/crates/fj-kernel/src/partial/maybe_partial.rs +++ b/crates/fj-kernel/src/partial/maybe_partial.rs @@ -279,6 +279,14 @@ impl MaybePartial { } impl MaybePartial { + /// Access the curve + pub fn curve(&self) -> MaybePartial { + match self { + Self::Full(full) => full.curve().clone().into(), + Self::Partial(partial) => partial.curve.clone(), + } + } + /// Access the surface form pub fn surface_form(&self) -> MaybePartial { match self { From 7f575eed38e2aa751fa2b440d2fa006927c4675c Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 30 Nov 2022 13:28:18 +0100 Subject: [PATCH 03/11] Construct `PartialHalfEdge` more thoroughly --- crates/fj-kernel/src/builder/shell.rs | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/crates/fj-kernel/src/builder/shell.rs b/crates/fj-kernel/src/builder/shell.rs index ff18342a2..61f31ea1d 100644 --- a/crates/fj-kernel/src/builder/shell.rs +++ b/crates/fj-kernel/src/builder/shell.rs @@ -162,13 +162,15 @@ impl ShellBuilder { }; PartialHalfEdge { - curve: curve.into(), + curve: curve.clone().into(), vertices: [ PartialVertex { + curve: curve.clone().into(), surface_form: from.into(), ..Default::default() }, PartialVertex { + curve: curve.into(), surface_form: to.into(), ..Default::default() }, From ced0a6965b427119d7688d841fa48e9d005b5c9e Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 30 Nov 2022 13:43:40 +0100 Subject: [PATCH 04/11] Fix `Replace` impl for `PartialVertex` --- crates/fj-kernel/src/partial/objects/vertex.rs | 1 + 1 file changed, 1 insertion(+) diff --git a/crates/fj-kernel/src/partial/objects/vertex.rs b/crates/fj-kernel/src/partial/objects/vertex.rs index 9ebab2aca..ecb4a49d7 100644 --- a/crates/fj-kernel/src/partial/objects/vertex.rs +++ b/crates/fj-kernel/src/partial/objects/vertex.rs @@ -69,6 +69,7 @@ impl MergeWith for PartialVertex { impl Replace for PartialVertex { fn replace(&mut self, surface: Handle) -> &mut Self { + self.curve.replace(surface.clone()); self.surface_form.replace(surface); self } From 6574582a2d7730086405d91c58ff91a13613d376 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 30 Nov 2022 13:44:58 +0100 Subject: [PATCH 05/11] Remove redundant struct field --- crates/fj-kernel/src/builder/cycle.rs | 1 - crates/fj-kernel/src/builder/edge.rs | 2 -- crates/fj-kernel/src/builder/shell.rs | 2 -- crates/fj-kernel/src/partial/objects/edge.rs | 23 +++++++------------- 4 files changed, 8 insertions(+), 20 deletions(-) diff --git a/crates/fj-kernel/src/builder/cycle.rs b/crates/fj-kernel/src/builder/cycle.rs index 62e34b27a..1a44832e9 100644 --- a/crates/fj-kernel/src/builder/cycle.rs +++ b/crates/fj-kernel/src/builder/cycle.rs @@ -83,7 +83,6 @@ impl CycleBuilder for PartialCycle { ); half_edges.push(PartialHalfEdge { - curve: curve.into(), vertices: vertices.map(Into::into), ..Default::default() }); diff --git a/crates/fj-kernel/src/builder/edge.rs b/crates/fj-kernel/src/builder/edge.rs index 47eba2bf2..0f44ee1f6 100644 --- a/crates/fj-kernel/src/builder/edge.rs +++ b/crates/fj-kernel/src/builder/edge.rs @@ -98,7 +98,6 @@ impl HalfEdgeBuilder for PartialHalfEdge { surface_form: surface_vertex.clone().into(), }); - self.curve = curve.into(); self.vertices = [back, front].map(Into::into); self @@ -201,7 +200,6 @@ impl HalfEdgeBuilder for PartialHalfEdge { }) }; - self.curve = curve.into(); self.vertices = [back, front]; self diff --git a/crates/fj-kernel/src/builder/shell.rs b/crates/fj-kernel/src/builder/shell.rs index 61f31ea1d..4153b1982 100644 --- a/crates/fj-kernel/src/builder/shell.rs +++ b/crates/fj-kernel/src/builder/shell.rs @@ -162,7 +162,6 @@ impl ShellBuilder { }; PartialHalfEdge { - curve: curve.clone().into(), vertices: [ PartialVertex { curve: curve.clone().into(), @@ -290,7 +289,6 @@ impl ShellBuilder { PartialHalfEdge { vertices: vertices.map(Into::into), global_form: edge.global_form().clone().into(), - ..Default::default() } .update_as_line_segment() .build(objects) diff --git a/crates/fj-kernel/src/partial/objects/edge.rs b/crates/fj-kernel/src/partial/objects/edge.rs index e840ea672..481ea8dee 100644 --- a/crates/fj-kernel/src/partial/objects/edge.rs +++ b/crates/fj-kernel/src/partial/objects/edge.rs @@ -14,9 +14,6 @@ use crate::{ /// See [`crate::partial`] for more information. #[derive(Clone, Debug, Default)] pub struct PartialHalfEdge { - /// The curve that the [`HalfEdge`] is defined in - pub curve: MaybePartial, - /// The vertices that bound the [`HalfEdge`] in the curve pub vertices: [MaybePartial; 2], @@ -27,24 +24,24 @@ pub struct PartialHalfEdge { impl PartialHalfEdge { /// Access the partial half-edge's curve pub fn curve(&self) -> MaybePartial { - self.curve.clone() + let [a, b] = &self.vertices; + a.curve().merge_with(b.curve()) } /// Build a full [`HalfEdge`] from the partial half-edge - pub fn build(mut self, objects: &mut Service) -> HalfEdge { + pub fn build(self, objects: &mut Service) -> HalfEdge { let global_curve = self .curve() .global_form() .merge_with(self.global_form.curve()); - let curve = { - self.curve = self.curve().merge_with(PartialCurve { + let curve = self + .curve() + .merge_with(PartialCurve { global_form: global_curve, ..Default::default() - }); - - self.curve.into_full(objects) - }; + }) + .into_full(objects); let vertices = self.vertices.map(|vertex| { vertex .merge_with(PartialVertex { @@ -70,7 +67,6 @@ impl MergeWith for PartialHalfEdge { let other = other.into(); Self { - curve: self.curve.merge_with(other.curve), vertices: self.vertices.merge_with(other.vertices), global_form: self.global_form.merge_with(other.global_form), } @@ -79,8 +75,6 @@ impl MergeWith for PartialHalfEdge { impl Replace for PartialHalfEdge { fn replace(&mut self, surface: Handle) -> &mut Self { - self.curve.replace(surface.clone()); - for vertex in &mut self.vertices { vertex.replace(surface.clone()); } @@ -95,7 +89,6 @@ impl From<&HalfEdge> for PartialHalfEdge { half_edge.vertices().clone().map(Into::into); Self { - curve: half_edge.curve().clone().into(), vertices: [back_vertex, front_vertex], global_form: half_edge.global_form().clone().into(), } From 9268f9b19aefaae8199c05108e72bd0f4a7abbaa Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 30 Nov 2022 14:23:39 +0100 Subject: [PATCH 06/11] Refactor --- crates/fj-kernel/src/validate/face.rs | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/crates/fj-kernel/src/validate/face.rs b/crates/fj-kernel/src/validate/face.rs index db9a082ec..9b94a3712 100644 --- a/crates/fj-kernel/src/validate/face.rs +++ b/crates/fj-kernel/src/validate/face.rs @@ -117,8 +117,10 @@ mod tests { fn face_surface_mismatch() { let mut services = Services::new(); + let surface = services.objects.surfaces.xy_plane(); + let valid = Face::partial() - .with_surface(services.objects.surfaces.xy_plane()) + .with_surface(surface) .with_exterior_polygon_from_points([[0., 0.], [3., 0.], [0., 3.]]) .with_interior_polygon_from_points([[1., 1.], [1., 2.], [2., 1.]]) .build(&mut services.objects); @@ -143,8 +145,10 @@ mod tests { fn face_invalid_interior_winding() { let mut services = Services::new(); + let surface = services.objects.surfaces.xy_plane(); + let valid = Face::partial() - .with_surface(services.objects.surfaces.xy_plane()) + .with_surface(surface) .with_exterior_polygon_from_points([[0., 0.], [3., 0.], [0., 3.]]) .with_interior_polygon_from_points([[1., 1.], [1., 2.], [2., 1.]]) .build(&mut services.objects); From a1da7e42be043143449d1a59acd7f5067816a18e Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 30 Nov 2022 14:27:30 +0100 Subject: [PATCH 07/11] Pass surface directly into method that needs it --- .../src/algorithms/intersect/curve_face.rs | 4 +- .../src/algorithms/intersect/face_face.rs | 6 +- .../src/algorithms/intersect/face_point.rs | 64 +++++++-------- .../src/algorithms/intersect/ray_face.rs | 77 +++++++------------ crates/fj-kernel/src/algorithms/sweep/face.rs | 16 ++-- .../src/algorithms/triangulate/mod.rs | 8 +- crates/fj-kernel/src/builder/face.rs | 7 +- crates/fj-kernel/src/builder/shell.rs | 11 +-- crates/fj-kernel/src/builder/sketch.rs | 3 +- crates/fj-kernel/src/iter.rs | 12 ++- crates/fj-kernel/src/validate/face.rs | 14 +++- crates/fj-operations/src/sketch.rs | 3 +- 12 files changed, 103 insertions(+), 122 deletions(-) diff --git a/crates/fj-kernel/src/algorithms/intersect/curve_face.rs b/crates/fj-kernel/src/algorithms/intersect/curve_face.rs index 7aee99816..8aec02c85 100644 --- a/crates/fj-kernel/src/algorithms/intersect/curve_face.rs +++ b/crates/fj-kernel/src/algorithms/intersect/curve_face.rs @@ -187,8 +187,8 @@ mod tests { ]; let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points(exterior) + .with_surface(surface.clone()) + .with_exterior_polygon_from_points(surface, exterior) .with_interior_polygon_from_points(interior) .build(&mut services.objects); diff --git a/crates/fj-kernel/src/algorithms/intersect/face_face.rs b/crates/fj-kernel/src/algorithms/intersect/face_face.rs index f7dd3549e..c9669e75d 100644 --- a/crates/fj-kernel/src/algorithms/intersect/face_face.rs +++ b/crates/fj-kernel/src/algorithms/intersect/face_face.rs @@ -95,8 +95,7 @@ mod tests { ] .map(|surface| { Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points(points) + .with_exterior_polygon_from_points(surface, points) .build(&mut services.objects) }); @@ -123,8 +122,7 @@ mod tests { ]; let [a, b] = surfaces.clone().map(|surface| { Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points(points) + .with_exterior_polygon_from_points(surface, points) .build(&mut services.objects) }); diff --git a/crates/fj-kernel/src/algorithms/intersect/face_point.rs b/crates/fj-kernel/src/algorithms/intersect/face_point.rs index 90aea9fdc..021f18ae4 100644 --- a/crates/fj-kernel/src/algorithms/intersect/face_point.rs +++ b/crates/fj-kernel/src/algorithms/intersect/face_point.rs @@ -150,8 +150,10 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([[0., 0.], [1., 1.], [0., 2.]]) + .with_exterior_polygon_from_points( + surface, + [[0., 0.], [1., 1.], [0., 2.]], + ) .build(&mut services.objects) .insert(&mut services.objects); let point = Point::from([2., 1.]); @@ -166,8 +168,10 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([[0., 0.], [2., 1.], [0., 2.]]) + .with_exterior_polygon_from_points( + surface, + [[0., 0.], [2., 1.], [0., 2.]], + ) .build(&mut services.objects) .insert(&mut services.objects); let point = Point::from([1., 1.]); @@ -185,8 +189,10 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([[4., 2.], [0., 4.], [0., 0.]]) + .with_exterior_polygon_from_points( + surface, + [[4., 2.], [0., 4.], [0., 0.]], + ) .build(&mut services.objects) .insert(&mut services.objects); let point = Point::from([1., 2.]); @@ -204,13 +210,10 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([ - [0., 0.], - [2., 1.], - [3., 0.], - [3., 4.], - ]) + .with_exterior_polygon_from_points( + surface, + [[0., 0.], [2., 1.], [3., 0.], [3., 4.]], + ) .build(&mut services.objects) .insert(&mut services.objects); let point = Point::from([1., 1.]); @@ -228,13 +231,10 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([ - [0., 0.], - [2., 1.], - [3., 1.], - [0., 2.], - ]) + .with_exterior_polygon_from_points( + surface, + [[0., 0.], [2., 1.], [3., 1.], [0., 2.]], + ) .build(&mut services.objects) .insert(&mut services.objects); let point = Point::from([1., 1.]); @@ -252,14 +252,10 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([ - [0., 0.], - [2., 1.], - [3., 1.], - [4., 0.], - [4., 5.], - ]) + .with_exterior_polygon_from_points( + surface, + [[0., 0.], [2., 1.], [3., 1.], [4., 0.], [4., 5.]], + ) .build(&mut services.objects) .insert(&mut services.objects); let point = Point::from([1., 1.]); @@ -277,8 +273,10 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([[0., 0.], [2., 0.], [0., 1.]]) + .with_exterior_polygon_from_points( + surface, + [[0., 0.], [2., 0.], [0., 1.]], + ) .build(&mut services.objects) .insert(&mut services.objects); let point = Point::from([1., 0.]); @@ -305,8 +303,10 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([[0., 0.], [1., 0.], [0., 1.]]) + .with_exterior_polygon_from_points( + surface, + [[0., 0.], [1., 0.], [0., 1.]], + ) .build(&mut services.objects) .insert(&mut services.objects); let point = Point::from([1., 0.]); diff --git a/crates/fj-kernel/src/algorithms/intersect/ray_face.rs b/crates/fj-kernel/src/algorithms/intersect/ray_face.rs index 5bc0273c1..bcb140734 100644 --- a/crates/fj-kernel/src/algorithms/intersect/ray_face.rs +++ b/crates/fj-kernel/src/algorithms/intersect/ray_face.rs @@ -168,13 +168,10 @@ mod tests { let surface = services.objects.surfaces.yz_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([ - [-1., -1.], - [1., -1.], - [1., 1.], - [-1., 1.], - ]) + .with_exterior_polygon_from_points( + surface, + [[-1., -1.], [1., -1.], [1., 1.], [-1., 1.]], + ) .build(&mut services.objects) .insert(&mut services.objects) .translate([-1., 0., 0.], &mut services.objects); @@ -190,13 +187,10 @@ mod tests { let surface = services.objects.surfaces.yz_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([ - [-1., -1.], - [1., -1.], - [1., 1.], - [-1., 1.], - ]) + .with_exterior_polygon_from_points( + surface, + [[-1., -1.], [1., -1.], [1., 1.], [-1., 1.]], + ) .build(&mut services.objects) .insert(&mut services.objects) .translate([1., 0., 0.], &mut services.objects); @@ -215,13 +209,10 @@ mod tests { let surface = services.objects.surfaces.yz_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([ - [-1., -1.], - [1., -1.], - [1., 1.], - [-1., 1.], - ]) + .with_exterior_polygon_from_points( + surface, + [[-1., -1.], [1., -1.], [1., 1.], [-1., 1.]], + ) .build(&mut services.objects) .insert(&mut services.objects) .translate([0., 0., 2.], &mut services.objects); @@ -237,13 +228,10 @@ mod tests { let surface = services.objects.surfaces.yz_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([ - [-1., -1.], - [1., -1.], - [1., 1.], - [-1., 1.], - ]) + .with_exterior_polygon_from_points( + surface, + [[-1., -1.], [1., -1.], [1., 1.], [-1., 1.]], + ) .build(&mut services.objects) .insert(&mut services.objects) .translate([1., 1., 0.], &mut services.objects); @@ -270,13 +258,10 @@ mod tests { let surface = services.objects.surfaces.yz_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([ - [-1., -1.], - [1., -1.], - [1., 1.], - [-1., 1.], - ]) + .with_exterior_polygon_from_points( + surface, + [[-1., -1.], [1., -1.], [1., 1.], [-1., 1.]], + ) .build(&mut services.objects) .insert(&mut services.objects) .translate([1., 1., 1.], &mut services.objects); @@ -301,13 +286,10 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([ - [-1., -1.], - [1., -1.], - [1., 1.], - [-1., 1.], - ]) + .with_exterior_polygon_from_points( + surface, + [[-1., -1.], [1., -1.], [1., 1.], [-1., 1.]], + ) .build(&mut services.objects) .insert(&mut services.objects); @@ -325,13 +307,10 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([ - [-1., -1.], - [1., -1.], - [1., 1.], - [-1., 1.], - ]) + .with_exterior_polygon_from_points( + surface, + [[-1., -1.], [1., -1.], [1., 1.], [-1., 1.]], + ) .build(&mut services.objects) .insert(&mut services.objects) .translate([0., 0., 1.], &mut services.objects); diff --git a/crates/fj-kernel/src/algorithms/sweep/face.rs b/crates/fj-kernel/src/algorithms/sweep/face.rs index 0abe0d756..1b03318a7 100644 --- a/crates/fj-kernel/src/algorithms/sweep/face.rs +++ b/crates/fj-kernel/src/algorithms/sweep/face.rs @@ -110,14 +110,15 @@ mod tests { .sweep(UP, &mut services.objects); let bottom = Face::partial() - .with_surface(surface.clone()) - .with_exterior_polygon_from_points(TRIANGLE) + .with_exterior_polygon_from_points(surface.clone(), TRIANGLE) .build(&mut services.objects) .insert(&mut services.objects) .reverse(&mut services.objects); let top = Face::partial() - .with_surface(surface.translate(UP, &mut services.objects)) - .with_exterior_polygon_from_points(TRIANGLE) + .with_exterior_polygon_from_points( + surface.translate(UP, &mut services.objects), + TRIANGLE, + ) .build(&mut services.objects) .insert(&mut services.objects); @@ -153,16 +154,15 @@ mod tests { .sweep(DOWN, &mut services.objects); let bottom = Face::partial() - .with_surface( + .with_exterior_polygon_from_points( surface.clone().translate(DOWN, &mut services.objects), + TRIANGLE, ) - .with_exterior_polygon_from_points(TRIANGLE) .build(&mut services.objects) .insert(&mut services.objects) .reverse(&mut services.objects); let top = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points(TRIANGLE) + .with_exterior_polygon_from_points(surface, TRIANGLE) .build(&mut services.objects) .insert(&mut services.objects); diff --git a/crates/fj-kernel/src/algorithms/triangulate/mod.rs b/crates/fj-kernel/src/algorithms/triangulate/mod.rs index ac1e19022..4ca44e92e 100644 --- a/crates/fj-kernel/src/algorithms/triangulate/mod.rs +++ b/crates/fj-kernel/src/algorithms/triangulate/mod.rs @@ -98,8 +98,7 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([a, b, c, d]) + .with_exterior_polygon_from_points(surface, [a, b, c, d]) .build(&mut services.objects) .insert(&mut services.objects); @@ -135,7 +134,7 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() .with_surface(surface.clone()) - .with_exterior_polygon_from_points([a, b, c, d]) + .with_exterior_polygon_from_points(surface.clone(), [a, b, c, d]) .with_interior_polygon_from_points([e, f, g, h]) .build(&mut services.objects) .insert(&mut services.objects); @@ -193,8 +192,7 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface.clone()) - .with_exterior_polygon_from_points([a, b, c, d, e]) + .with_exterior_polygon_from_points(surface.clone(), [a, b, c, d, e]) .build(&mut services.objects) .insert(&mut services.objects); diff --git a/crates/fj-kernel/src/builder/face.rs b/crates/fj-kernel/src/builder/face.rs index 41f6dc5b1..826ba58cb 100644 --- a/crates/fj-kernel/src/builder/face.rs +++ b/crates/fj-kernel/src/builder/face.rs @@ -1,8 +1,9 @@ use fj_math::Point; use crate::{ - objects::Cycle, + objects::{Cycle, Surface}, partial::{HasPartial, PartialFace}, + storage::Handle, }; use super::CycleBuilder; @@ -12,6 +13,7 @@ pub trait FaceBuilder { /// Update the [`PartialFace`] with an exterior polygon fn with_exterior_polygon_from_points( self, + surface: Handle, points: impl IntoIterator>>, ) -> Self; @@ -25,10 +27,9 @@ pub trait FaceBuilder { impl FaceBuilder for PartialFace { fn with_exterior_polygon_from_points( self, + surface: Handle, points: impl IntoIterator>>, ) -> Self { - let surface = self.surface().expect("Need surface to create polygon"); - self.with_exterior( Cycle::partial() .with_poly_chain_from_points(surface, points) diff --git a/crates/fj-kernel/src/builder/shell.rs b/crates/fj-kernel/src/builder/shell.rs index 4153b1982..7b6b086a9 100644 --- a/crates/fj-kernel/src/builder/shell.rs +++ b/crates/fj-kernel/src/builder/shell.rs @@ -52,13 +52,10 @@ impl ShellBuilder { objects.surfaces.xy_plane().translate([Z, Z, -h], objects); Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([ - [-h, -h], - [h, -h], - [h, h], - [-h, h], - ]) + .with_exterior_polygon_from_points( + surface, + [[-h, -h], [h, -h], [h, h], [-h, h]], + ) .build(objects) .insert(objects) }; diff --git a/crates/fj-kernel/src/builder/sketch.rs b/crates/fj-kernel/src/builder/sketch.rs index 5ce8e8470..afb649241 100644 --- a/crates/fj-kernel/src/builder/sketch.rs +++ b/crates/fj-kernel/src/builder/sketch.rs @@ -48,8 +48,7 @@ impl SketchBuilder { .as_ref() .expect("Can't build `Sketch` without `Surface`"); self.faces.extend([Face::partial() - .with_surface(surface.clone()) - .with_exterior_polygon_from_points(points) + .with_exterior_polygon_from_points(surface.clone(), points) .build(objects) .insert(objects)]); self diff --git a/crates/fj-kernel/src/iter.rs b/crates/fj-kernel/src/iter.rs index ee26673b3..2be2ac8c5 100644 --- a/crates/fj-kernel/src/iter.rs +++ b/crates/fj-kernel/src/iter.rs @@ -432,8 +432,10 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let object = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([[0., 0.], [1., 0.], [0., 1.]]) + .with_exterior_polygon_from_points( + surface, + [[0., 0.], [1., 0.], [0., 1.]], + ) .build(&mut services.objects) .insert(&mut services.objects); @@ -541,8 +543,10 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([[0., 0.], [1., 0.], [0., 1.]]) + .with_exterior_polygon_from_points( + surface, + [[0., 0.], [1., 0.], [0., 1.]], + ) .build(&mut services.objects) .insert(&mut services.objects); let object = Sketch::builder() diff --git a/crates/fj-kernel/src/validate/face.rs b/crates/fj-kernel/src/validate/face.rs index 9b94a3712..723a5171a 100644 --- a/crates/fj-kernel/src/validate/face.rs +++ b/crates/fj-kernel/src/validate/face.rs @@ -120,8 +120,11 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let valid = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([[0., 0.], [3., 0.], [0., 3.]]) + .with_surface(surface.clone()) + .with_exterior_polygon_from_points( + surface, + [[0., 0.], [3., 0.], [0., 3.]], + ) .with_interior_polygon_from_points([[1., 1.], [1., 2.], [2., 1.]]) .build(&mut services.objects); let invalid = { @@ -148,8 +151,11 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let valid = Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points([[0., 0.], [3., 0.], [0., 3.]]) + .with_surface(surface.clone()) + .with_exterior_polygon_from_points( + surface, + [[0., 0.], [3., 0.], [0., 3.]], + ) .with_interior_polygon_from_points([[1., 1.], [1., 2.], [2., 1.]]) .build(&mut services.objects); let invalid = { diff --git a/crates/fj-operations/src/sketch.rs b/crates/fj-operations/src/sketch.rs index 375409366..69c24790d 100644 --- a/crates/fj-operations/src/sketch.rs +++ b/crates/fj-operations/src/sketch.rs @@ -51,8 +51,7 @@ impl Shape for fj::Sketch { .map(Point::from); Face::partial() - .with_surface(surface) - .with_exterior_polygon_from_points(points) + .with_exterior_polygon_from_points(surface, points) .with_color(Color(self.color())) .build(objects) .insert(objects) From 54b4778265a785f0375f907553e414ea088dd5a6 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 30 Nov 2022 14:29:25 +0100 Subject: [PATCH 08/11] Pass surface directly into method that needs it --- .../src/algorithms/intersect/curve_face.rs | 5 ++--- .../fj-kernel/src/algorithms/triangulate/mod.rs | 3 +-- crates/fj-kernel/src/builder/face.rs | 4 ++-- crates/fj-kernel/src/validate/face.rs | 16 ++++++++++------ 4 files changed, 15 insertions(+), 13 deletions(-) diff --git a/crates/fj-kernel/src/algorithms/intersect/curve_face.rs b/crates/fj-kernel/src/algorithms/intersect/curve_face.rs index 8aec02c85..dfe0cb790 100644 --- a/crates/fj-kernel/src/algorithms/intersect/curve_face.rs +++ b/crates/fj-kernel/src/algorithms/intersect/curve_face.rs @@ -187,9 +187,8 @@ mod tests { ]; let face = Face::partial() - .with_surface(surface.clone()) - .with_exterior_polygon_from_points(surface, exterior) - .with_interior_polygon_from_points(interior) + .with_exterior_polygon_from_points(surface.clone(), exterior) + .with_interior_polygon_from_points(surface, interior) .build(&mut services.objects); let expected = diff --git a/crates/fj-kernel/src/algorithms/triangulate/mod.rs b/crates/fj-kernel/src/algorithms/triangulate/mod.rs index 4ca44e92e..3e83522f9 100644 --- a/crates/fj-kernel/src/algorithms/triangulate/mod.rs +++ b/crates/fj-kernel/src/algorithms/triangulate/mod.rs @@ -133,9 +133,8 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let face = Face::partial() - .with_surface(surface.clone()) .with_exterior_polygon_from_points(surface.clone(), [a, b, c, d]) - .with_interior_polygon_from_points([e, f, g, h]) + .with_interior_polygon_from_points(surface.clone(), [e, f, g, h]) .build(&mut services.objects) .insert(&mut services.objects); diff --git a/crates/fj-kernel/src/builder/face.rs b/crates/fj-kernel/src/builder/face.rs index 826ba58cb..e3f1c7065 100644 --- a/crates/fj-kernel/src/builder/face.rs +++ b/crates/fj-kernel/src/builder/face.rs @@ -20,6 +20,7 @@ pub trait FaceBuilder { /// Update the [`PartialFace`] with an interior polygon fn with_interior_polygon_from_points( self, + surface: Handle, points: impl IntoIterator>>, ) -> Self; } @@ -39,10 +40,9 @@ impl FaceBuilder for PartialFace { fn with_interior_polygon_from_points( self, + surface: Handle, points: impl IntoIterator>>, ) -> Self { - let surface = self.surface().expect("Need surface to build polygon."); - self.with_interiors([Cycle::partial() .with_poly_chain_from_points(surface, points) .close_with_line_segment()]) diff --git a/crates/fj-kernel/src/validate/face.rs b/crates/fj-kernel/src/validate/face.rs index 723a5171a..67208e1ea 100644 --- a/crates/fj-kernel/src/validate/face.rs +++ b/crates/fj-kernel/src/validate/face.rs @@ -120,12 +120,14 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let valid = Face::partial() - .with_surface(surface.clone()) .with_exterior_polygon_from_points( - surface, + surface.clone(), [[0., 0.], [3., 0.], [0., 3.]], ) - .with_interior_polygon_from_points([[1., 1.], [1., 2.], [2., 1.]]) + .with_interior_polygon_from_points( + surface, + [[1., 1.], [1., 2.], [2., 1.]], + ) .build(&mut services.objects); let invalid = { let interiors = [Cycle::partial() @@ -151,12 +153,14 @@ mod tests { let surface = services.objects.surfaces.xy_plane(); let valid = Face::partial() - .with_surface(surface.clone()) .with_exterior_polygon_from_points( - surface, + surface.clone(), [[0., 0.], [3., 0.], [0., 3.]], ) - .with_interior_polygon_from_points([[1., 1.], [1., 2.], [2., 1.]]) + .with_interior_polygon_from_points( + surface, + [[1., 1.], [1., 2.], [2., 1.]], + ) .build(&mut services.objects); let invalid = { let interiors = valid From 57100a20522e3b62cf1d1a7d4ac78a35eb8c46b8 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 30 Nov 2022 14:30:31 +0100 Subject: [PATCH 09/11] Remove unused code --- crates/fj-kernel/src/partial/objects/face.rs | 6 ------ 1 file changed, 6 deletions(-) diff --git a/crates/fj-kernel/src/partial/objects/face.rs b/crates/fj-kernel/src/partial/objects/face.rs index a2383ed91..5016f6b3e 100644 --- a/crates/fj-kernel/src/partial/objects/face.rs +++ b/crates/fj-kernel/src/partial/objects/face.rs @@ -39,12 +39,6 @@ impl PartialFace { self.color } - /// Build the [`Face`] with the provided surface - pub fn with_surface(mut self, surface: Handle) -> Self { - self.surface = Some(surface); - self - } - /// Build the [`Face`] with the provided exterior pub fn with_exterior( mut self, From 55c0f61f3c075a6dffa727169e788ca6fa35d6d8 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 30 Nov 2022 14:32:05 +0100 Subject: [PATCH 10/11] Add `MaybePartial::surface` --- crates/fj-kernel/src/partial/maybe_partial.rs | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/crates/fj-kernel/src/partial/maybe_partial.rs b/crates/fj-kernel/src/partial/maybe_partial.rs index 2d6f9d41b..6d8e370d2 100644 --- a/crates/fj-kernel/src/partial/maybe_partial.rs +++ b/crates/fj-kernel/src/partial/maybe_partial.rs @@ -5,7 +5,7 @@ use crate::{ get::Get, insert::Insert, objects::{ - Curve, GlobalCurve, GlobalEdge, GlobalVertex, HalfEdge, Objects, + Curve, Cycle, GlobalCurve, GlobalEdge, GlobalVertex, HalfEdge, Objects, Surface, SurfaceVertex, Vertex, }, services::Service, @@ -183,6 +183,16 @@ impl MaybePartial { } } +impl MaybePartial { + /// Access the surface + pub fn surface(&self) -> Option> { + match self { + Self::Full(full) => full.surface().clone().into(), + Self::Partial(partial) => partial.surface(), + } + } +} + impl MaybePartial { /// Access the curve pub fn curve(&self) -> MaybePartial { From ec1f88ecdc6cf70e96b1216f779648ed541e9f65 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Wed, 30 Nov 2022 14:32:21 +0100 Subject: [PATCH 11/11] Remove redundant struct field --- crates/fj-kernel/src/partial/objects/face.rs | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/crates/fj-kernel/src/partial/objects/face.rs b/crates/fj-kernel/src/partial/objects/face.rs index 5016f6b3e..85e044d37 100644 --- a/crates/fj-kernel/src/partial/objects/face.rs +++ b/crates/fj-kernel/src/partial/objects/face.rs @@ -12,7 +12,6 @@ use crate::{ /// See [`crate::partial`] for more information. #[derive(Clone, Debug, Default)] pub struct PartialFace { - surface: Option>, exterior: MaybePartial, interiors: Vec>, color: Option, @@ -21,7 +20,7 @@ pub struct PartialFace { impl PartialFace { /// Access th surface that the [`Face`] is defined in pub fn surface(&self) -> Option> { - self.surface.clone() + self.exterior.surface() } /// Access the [`Face`]'s exterior cycle @@ -83,7 +82,6 @@ impl MergeWith for PartialFace { let other = other.into(); Self { - surface: self.surface.merge_with(other.surface), exterior: self.exterior.merge_with(other.exterior), interiors: Mergeable(self.interiors) .merge_with(Mergeable(other.interiors)) @@ -96,7 +94,6 @@ impl MergeWith for PartialFace { impl From<&Face> for PartialFace { fn from(face: &Face) -> Self { Self { - surface: Some(face.surface().clone()), exterior: face.exterior().clone().into(), interiors: face.interiors().cloned().map(Into::into).collect(), color: Some(face.color()),