Skip to content

Commit

Permalink
Remove redundant constructor argument
Browse files Browse the repository at this point in the history
  • Loading branch information
hannobraun committed Nov 2, 2022
1 parent 5083768 commit bb788b0
Show file tree
Hide file tree
Showing 6 changed files with 17 additions and 26 deletions.
4 changes: 1 addition & 3 deletions crates/fj-kernel/src/algorithms/reverse/cycle.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,6 @@ use super::Reverse;

impl Reverse for Handle<Cycle> {
fn reverse(self, objects: &Objects) -> Result<Self, ValidationError> {
let surface = self.surface().clone();

let mut edges = self
.half_edges()
.cloned()
Expand All @@ -18,6 +16,6 @@ impl Reverse for Handle<Cycle> {

edges.reverse();

Ok(objects.cycles.insert(Cycle::new(surface, edges))?)
Ok(objects.cycles.insert(Cycle::new(edges))?)
}
}
17 changes: 6 additions & 11 deletions crates/fj-kernel/src/algorithms/sweep/edge.rs
Original file line number Diff line number Diff line change
Expand Up @@ -121,11 +121,7 @@ impl Sweep for (Handle<HalfEdge>, Color) {
points_curve_and_surface,
));

objects.curves.insert(Curve::new(
surface.clone(),
path,
global,
))?
objects.curves.insert(Curve::new(surface, path, global))?
};

let global = objects.global_edges.insert(GlobalEdge::new(
Expand Down Expand Up @@ -176,7 +172,7 @@ impl Sweep for (Handle<HalfEdge>, Color) {
i += 1;
}

objects.cycles.insert(Cycle::new(surface, edges))?
objects.cycles.insert(Cycle::new(edges))?
};

Ok(Face::builder(objects)
Expand Down Expand Up @@ -242,7 +238,7 @@ mod tests {
.build(&objects)?
.reverse(&objects)?;
let side_down = HalfEdge::partial()
.with_surface(Some(surface.clone()))
.with_surface(Some(surface))
.with_back_vertex(Some(Vertex::partial().with_surface_form(
Some(bottom.back().surface_form().clone()),
)))
Expand All @@ -253,10 +249,9 @@ mod tests {
.build(&objects)?
.reverse(&objects)?;

let cycle = objects.cycles.insert(Cycle::new(
surface,
[bottom, side_up, top, side_down],
))?;
let cycle = objects
.cycles
.insert(Cycle::new([bottom, side_up, top, side_down]))?;

Face::builder(&objects).with_exterior(cycle).build()
};
Expand Down
5 changes: 1 addition & 4 deletions crates/fj-kernel/src/builder/shell.rs
Original file line number Diff line number Diff line change
Expand Up @@ -260,10 +260,7 @@ impl<'a> ShellBuilder<'a> {

Face::builder(self.objects)
.with_exterior(
self.objects
.cycles
.insert(Cycle::new(surface, edges))
.unwrap(),
self.objects.cycles.insert(Cycle::new(edges)).unwrap(),
)
.build()
};
Expand Down
10 changes: 6 additions & 4 deletions crates/fj-kernel/src/objects/cycle.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,12 +20,14 @@ impl Cycle {
///
/// Panic, if the end of each half-edge does not connect to the beginning of
/// the next one.
pub fn new(
surface: Handle<Surface>,
half_edges: impl IntoIterator<Item = Handle<HalfEdge>>,
) -> Self {
pub fn new(half_edges: impl IntoIterator<Item = Handle<HalfEdge>>) -> Self {
let half_edges = half_edges.into_iter().collect::<Vec<_>>();

let surface = match half_edges.first() {
Some(half_edge) => half_edge.surface().clone(),
None => panic!("Cycle must contain at least one half-edge"),
};

// Verify, that the curves of all edges are defined in the correct
// surface.
for edge in &half_edges {
Expand Down
2 changes: 1 addition & 1 deletion crates/fj-kernel/src/partial/objects/cycle.rs
Original file line number Diff line number Diff line change
Expand Up @@ -222,7 +222,7 @@ impl PartialCycle {
half_edges
};

Ok(objects.cycles.insert(Cycle::new(surface, half_edges))?)
Ok(objects.cycles.insert(Cycle::new(half_edges))?)
}
}

Expand Down
5 changes: 2 additions & 3 deletions crates/fj-operations/src/sketch.rs
Original file line number Diff line number Diff line change
Expand Up @@ -27,11 +27,10 @@ impl Shape for fj::Sketch {
// none need to be added here.

let half_edge = HalfEdge::partial()
.with_surface(Some(surface.clone()))
.with_surface(Some(surface))
.as_circle_from_radius(circle.radius(), objects)?
.build(objects)?;
let cycle =
objects.cycles.insert(Cycle::new(surface, [half_edge]))?;
let cycle = objects.cycles.insert(Cycle::new([half_edge]))?;

Face::builder(objects)
.with_exterior(cycle)
Expand Down

0 comments on commit bb788b0

Please sign in to comment.