diff --git a/crates/fj-core/src/algorithms/intersect/mod.rs b/crates/fj-core/src/algorithms/intersect/mod.rs index 2adb21508..0d5781269 100644 --- a/crates/fj-core/src/algorithms/intersect/mod.rs +++ b/crates/fj-core/src/algorithms/intersect/mod.rs @@ -1,6 +1,5 @@ //! Intersection algorithms -pub mod ray_edge; pub mod ray_segment; mod line_segment; diff --git a/crates/fj-core/src/algorithms/intersect/ray_edge.rs b/crates/fj-core/src/algorithms/intersect/ray_edge.rs deleted file mode 100644 index dab988e9d..000000000 --- a/crates/fj-core/src/algorithms/intersect/ray_edge.rs +++ /dev/null @@ -1,35 +0,0 @@ -//! Intersection between a ray and an edge in 2D - -use fj_math::Segment; - -use crate::{ - algorithms::intersect::{HorizontalRayToTheRight, Intersect}, - geometry::SurfacePath, - objects::HalfEdge, - storage::Handle, -}; - -use super::ray_segment::RaySegmentIntersection; - -impl Intersect for (&HorizontalRayToTheRight<2>, &Handle) { - type Intersection = RaySegmentIntersection; - - fn intersect(self) -> Option { - let (ray, edge) = self; - - let line = match edge.path() { - SurfacePath::Line(line) => line, - SurfacePath::Circle(_) => { - todo!("Casting rays against circles is not supported yet") - } - }; - - let points = edge - .boundary() - .inner - .map(|point| line.point_from_line_coords(point)); - let segment = Segment::from_points(points); - - (ray, &segment).intersect() - } -}