From b44da4ccfdecaa8e7250edc04bbd476ea5b2d39d Mon Sep 17 00:00:00 2001 From: Yuri Astrakhan Date: Thu, 17 Mar 2022 22:34:59 -0400 Subject: [PATCH] Use `LineString::from_raw()` instead of `LineString()` Make migration simpler by using static function that will still be available if `LineString` becomes a type alias. Similar to https://github.com/georust/geo/pull/777 - [x] I agree to follow the project's [code of conduct](https://github.com/georust/geo/blob/master/CODE_OF_CONDUCT.md). - ~[ ] I added an entry to `CHANGES.md` if knowledge of this change could be valuable to users.~ --- --- geo-types/src/lib.rs | 4 ++-- geo-types/src/line_string.rs | 19 ++++++++++++------- geo/src/algorithm/centroid.rs | 3 +-- geo/src/algorithm/closest_point.rs | 3 +-- geo/src/algorithm/contains/mod.rs | 6 ++---- geo/src/algorithm/contains/triangle.rs | 2 +- geo/src/algorithm/convex_hull/graham.rs | 2 +- geo/src/algorithm/convex_hull/mod.rs | 2 +- geo/src/algorithm/coordinate_position.rs | 3 +-- geo/src/algorithm/dimensions.rs | 7 +++---- geo/src/algorithm/euclidean_distance.rs | 8 ++++---- geo/src/algorithm/intersects/mod.rs | 4 +--- geo/src/algorithm/k_nearest_concave_hull.rs | 7 +++---- geo/src/algorithm/line_locate_point.rs | 20 ++++++++++---------- 14 files changed, 43 insertions(+), 47 deletions(-) diff --git a/geo-types/src/lib.rs b/geo-types/src/lib.rs index cff6118066..5dad8e0a0f 100644 --- a/geo-types/src/lib.rs +++ b/geo-types/src/lib.rs @@ -168,13 +168,13 @@ mod tests { #[test] fn polygon_new_test() { - let exterior = LineString::from(vec![ + let exterior = LineString::from_raw(vec![ coord! { x: 0., y: 0. }, coord! { x: 1., y: 1. }, coord! { x: 1., y: 0. }, coord! { x: 0., y: 0. }, ]); - let interiors = vec![LineString::from(vec![ + let interiors = vec![LineString::from_raw(vec![ coord! { x: 0.1, y: 0.1 }, coord! { x: 0.9, y: 0.9 }, coord! { x: 0.9, y: 0.1 }, diff --git a/geo-types/src/line_string.rs b/geo-types/src/line_string.rs index 990c90b40c..d38c52490d 100644 --- a/geo-types/src/line_string.rs +++ b/geo-types/src/line_string.rs @@ -35,7 +35,7 @@ use std::ops::{Index, IndexMut}; /// ``` /// use geo_types::{coord, LineString}; /// -/// let line_string = LineString::from(vec![ +/// let line_string = LineString::from_raw(vec![ /// coord! { x: 0., y: 0. }, /// coord! { x: 10., y: 0. }, /// ]); @@ -83,7 +83,7 @@ use std::ops::{Index, IndexMut}; /// ``` /// use geo_types::{coord, LineString}; /// -/// let line_string = LineString::from(vec![ +/// let line_string = LineString::from_raw(vec![ /// coord! { x: 0., y: 0. }, /// coord! { x: 10., y: 0. }, /// ]); @@ -100,7 +100,7 @@ use std::ops::{Index, IndexMut}; /// ``` /// use geo_types::{coord, LineString}; /// -/// let line_string = LineString::from(vec![ +/// let line_string = LineString::from_raw(vec![ /// coord! { x: 0., y: 0. }, /// coord! { x: 10., y: 0. }, /// ]); @@ -120,7 +120,7 @@ use std::ops::{Index, IndexMut}; /// ``` /// use geo_types::{coord, LineString, Point}; /// -/// let line_string = LineString::from(vec![ +/// let line_string = LineString::from_raw(vec![ /// coord! { x: 0., y: 0. }, /// coord! { x: 10., y: 0. }, /// ]); @@ -191,6 +191,11 @@ impl<'a, T: CoordNum> DoubleEndedIterator for CoordinatesIter<'a, T> { } impl LineString { + /// Instantiate Self from the raw content value + pub fn from_raw(value: Vec>) -> Self { + Self(value) + } + /// Return an iterator yielding the coordinates of a [`LineString`] as [`Point`]s #[deprecated(note = "Use points() instead")] pub fn points_iter(&self) -> PointsIter { @@ -529,7 +534,7 @@ mod test { #[test] fn test_exact_size() { // see https://github.com/georust/geo/issues/762 - let ls = LineString::from(vec![coord! { x: 0., y: 0. }, coord! { x: 10., y: 0. }]); + let ls = LineString::from_raw(vec![coord! { x: 0., y: 0. }, coord! { x: 10., y: 0. }]); // reference to force the `impl IntoIterator for &LineString` impl, giving a `CoordinatesIter` for c in (&ls).into_iter().rev().skip(1).rev() { @@ -601,14 +606,14 @@ mod test { let start = coord! { x: 0, y: 0 }; let end = coord! { x: 10, y: 10 }; let line = Line::new(start, end); - let expected = LineString::from(vec![start, end]); + let expected = LineString::from_raw(vec![start, end]); assert_eq!(expected, LineString::from(line)); let start = coord! { x: 10., y: 0.5 }; let end = coord! { x: 10000., y: 10.4 }; let line = Line::new(start, end); - let expected = LineString::from(vec![start, end]); + let expected = LineString::from_raw(vec![start, end]); assert_eq!(expected, LineString::from(line)); } diff --git a/geo/src/algorithm/centroid.rs b/geo/src/algorithm/centroid.rs index 6192b28132..e576c62d18 100644 --- a/geo/src/algorithm/centroid.rs +++ b/geo/src/algorithm/centroid.rs @@ -725,10 +725,9 @@ mod test { } #[test] fn empty_interior_polygon_test() { - let empty: Vec> = vec![]; let poly = Polygon::new( LineString::from(vec![p(0., 0.), p(0., 1.), p(1., 1.), p(1., 0.), p(0., 0.)]), - vec![LineString::from(empty)], + vec![LineString::from_raw(vec![])], ); assert_eq!(poly.centroid(), Some(p(0.5, 0.5))); } diff --git a/geo/src/algorithm/closest_point.rs b/geo/src/algorithm/closest_point.rs index 281dc6299b..d2db486bf2 100644 --- a/geo/src/algorithm/closest_point.rs +++ b/geo/src/algorithm/closest_point.rs @@ -259,8 +259,7 @@ mod tests { #[test] fn empty_line_string_is_indeterminate() { - let empty: Vec> = Vec::new(); - let ls = LineString::from(empty); + let ls = LineString::from_raw(Vec::new()); let p = Point::new(0.0, 0.0); let got = ls.closest_point(&p); diff --git a/geo/src/algorithm/contains/mod.rs b/geo/src/algorithm/contains/mod.rs index 147970dd17..e664ede7ec 100644 --- a/geo/src/algorithm/contains/mod.rs +++ b/geo/src/algorithm/contains/mod.rs @@ -134,8 +134,7 @@ mod test { /// Tests: Point in LineString #[test] fn empty_linestring_test() { - let empty: Vec> = Vec::new(); - let linestring = LineString::from(empty); + let linestring = LineString::from_raw(Vec::new()); assert!(!linestring.contains(&Point::new(2., 1.))); } #[test] @@ -155,8 +154,7 @@ mod test { /// Tests: Point in Polygon #[test] fn empty_polygon_test() { - let empty: Vec> = Vec::new(); - let linestring = LineString::from(empty); + let linestring = LineString::from_raw(Vec::new()); let poly = Polygon::new(linestring, Vec::new()); assert!(!poly.contains(&Point::new(2., 1.))); } diff --git a/geo/src/algorithm/contains/triangle.rs b/geo/src/algorithm/contains/triangle.rs index b58fd07f24..4b185635aa 100644 --- a/geo/src/algorithm/contains/triangle.rs +++ b/geo/src/algorithm/contains/triangle.rs @@ -10,7 +10,7 @@ where T: GeoNum, { fn contains(&self, coord: &Coordinate) -> bool { - let ls = LineString::from(vec![self.0, self.1, self.2, self.0]); + let ls = LineString::from_raw(vec![self.0, self.1, self.2, self.0]); use crate::utils::{coord_pos_relative_to_ring, CoordPos}; coord_pos_relative_to_ring(*coord, &ls) == CoordPos::Inside } diff --git a/geo/src/algorithm/convex_hull/graham.rs b/geo/src/algorithm/convex_hull/graham.rs index b454a56e74..7a40fc9630 100644 --- a/geo/src/algorithm/convex_hull/graham.rs +++ b/geo/src/algorithm/convex_hull/graham.rs @@ -80,7 +80,7 @@ where } // Close and output the line string - let mut output = LineString::from(output); + let mut output = LineString::from_raw(output); output.close(); output } diff --git a/geo/src/algorithm/convex_hull/mod.rs b/geo/src/algorithm/convex_hull/mod.rs index 4b97c304ee..dc927cf56b 100644 --- a/geo/src/algorithm/convex_hull/mod.rs +++ b/geo/src/algorithm/convex_hull/mod.rs @@ -126,7 +126,7 @@ where ls.push(ls[0]); } - let mut ls = LineString::from(ls); + let mut ls = LineString::from_raw(ls); ls.close(); // Maintain the CCW invariance diff --git a/geo/src/algorithm/coordinate_position.rs b/geo/src/algorithm/coordinate_position.rs index f9fed03f86..2daf283cab 100644 --- a/geo/src/algorithm/coordinate_position.rs +++ b/geo/src/algorithm/coordinate_position.rs @@ -444,8 +444,7 @@ mod test { #[test] fn test_empty_poly() { - let empty: Vec> = vec![]; - let square_poly = Polygon::new(LineString::from(empty), vec![]); + let square_poly: Polygon = Polygon::new(LineString::from_raw(vec![]), vec![]); assert_eq!( square_poly.coordinate_position(&Coordinate::zero()), CoordPos::Outside diff --git a/geo/src/algorithm/dimensions.rs b/geo/src/algorithm/dimensions.rs index f3b6e39af1..0a84b6d125 100644 --- a/geo/src/algorithm/dimensions.rs +++ b/geo/src/algorithm/dimensions.rs @@ -43,17 +43,16 @@ pub trait HasDimensions { /// Types like `Point` and `Rect`, which have at least one coordinate by construction, can /// never be considered empty. /// ``` - /// use geo_types::{Point, coord, Coordinate, LineString}; + /// use geo_types::{Point, coord, LineString}; /// use geo::algorithm::dimensions::HasDimensions; /// - /// let line_string = LineString::from(vec![ + /// let line_string = LineString::from_raw(vec![ /// coord! { x: 0., y: 0. }, /// coord! { x: 10., y: 0. }, /// ]); /// assert!(!line_string.is_empty()); /// - /// let empty: Vec> = vec![]; - /// let empty_line_string = LineString::from(empty); + /// let empty_line_string: LineString = LineString::from_raw(vec![]); /// assert!(empty_line_string.is_empty()); /// /// let point = Point::new(0.0, 0.0); diff --git a/geo/src/algorithm/euclidean_distance.rs b/geo/src/algorithm/euclidean_distance.rs index e7bb564e98..3966bda5cb 100644 --- a/geo/src/algorithm/euclidean_distance.rs +++ b/geo/src/algorithm/euclidean_distance.rs @@ -687,8 +687,8 @@ mod test { // Point to Polygon, empty Polygon fn point_polygon_empty_test() { // an empty Polygon - let points: Vec> = vec![]; - let ls = LineString::from(points); + let points = vec![]; + let ls = LineString::from_raw(points); let poly = Polygon::new(ls, vec![]); // A point on the octagon let p = Point::new(2.5, 0.5); @@ -824,8 +824,8 @@ mod test { #[test] // Point to LineString, empty LineString fn point_linestring_empty_test() { - let points: Vec> = vec![]; - let ls = LineString::from(points); + let points = vec![]; + let ls = LineString::from_raw(points); let p = Point::new(5.0, 4.0); let dist = p.euclidean_distance(&ls); assert_relative_eq!(dist, 0.0); diff --git a/geo/src/algorithm/intersects/mod.rs b/geo/src/algorithm/intersects/mod.rs index 59c73aee8d..1b38149b9b 100644 --- a/geo/src/algorithm/intersects/mod.rs +++ b/geo/src/algorithm/intersects/mod.rs @@ -114,7 +114,6 @@ mod test { coord, line_string, polygon, Geometry, Line, LineString, MultiLineString, MultiPoint, MultiPolygon, Point, Polygon, Rect, }; - use geo_types::Coordinate; /// Tests: intersection LineString and LineString #[test] @@ -125,8 +124,7 @@ mod test { #[test] fn empty_linestring2_test() { let linestring = line_string![(x: 3., y: 2.), (x: 7., y: 6.)]; - let empty: Vec> = Vec::new(); - assert!(!linestring.intersects(&LineString::from(empty))); + assert!(!linestring.intersects(&LineString::from_raw(Vec::new()))); } #[test] fn empty_all_linestring_test() { diff --git a/geo/src/algorithm/k_nearest_concave_hull.rs b/geo/src/algorithm/k_nearest_concave_hull.rs index 9b7b497af6..e5357698f6 100644 --- a/geo/src/algorithm/k_nearest_concave_hull.rs +++ b/geo/src/algorithm/k_nearest_concave_hull.rs @@ -310,8 +310,8 @@ where return false; } - let coords: Vec> = hull.iter().take(hull.len() - 1).cloned().collect(); - let linestring = LineString::from(coords); + let coords = hull.iter().take(hull.len() - 1).cloned().collect(); + let linestring = LineString::from_raw(coords); let line = crate::Line::new(*line[0], *line[1]); linestring.intersects(&line) } @@ -402,8 +402,7 @@ mod tests { #[test] fn empty_hull() { let actual: Polygon = concave_hull(vec![].iter(), 3); - let empty: Vec> = vec![]; - let expected = Polygon::new(LineString::from(empty), vec![]); + let expected = Polygon::new(LineString::from_raw(vec![]), vec![]); assert_eq!(actual, expected); } } diff --git a/geo/src/algorithm/line_locate_point.rs b/geo/src/algorithm/line_locate_point.rs index 3c449f65c1..9445b5b397 100644 --- a/geo/src/algorithm/line_locate_point.rs +++ b/geo/src/algorithm/line_locate_point.rs @@ -111,7 +111,6 @@ mod test { use super::*; use crate::geo_types::coord; use crate::point; - use geo_types::Coordinate; use num_traits::Float; #[test] @@ -213,24 +212,25 @@ mod test { assert_eq!(ring.line_locate_point(&pt), None); // point is equidistant to two line segments - return the fraction from the first closest - let line: Vec> = vec![ + let line: LineString = LineString::from_raw(vec![ (0.0, 0.0).into(), (1.0, 0.0).into(), (1.0, 1.0).into(), (0.0, 1.0).into(), - ]; - let line = LineString::from(line); + ]); let pt = point!(x: 0.0, y: 0.5); assert_eq!(line.line_locate_point(&pt), Some(0.0)); - let line: Vec> = - vec![(1.0, 1.0).into(), (1.0, 1.0).into(), (1.0, 1.0).into()]; - let line = LineString::from(line); + let line: LineString = LineString::from_raw(vec![ + (1.0, 1.0).into(), + (1.0, 1.0).into(), + (1.0, 1.0).into(), + ]); let pt = point!(x: 2.0, y: 2.0); assert_eq!(line.line_locate_point(&pt), Some(0.0)); // line contains inf or nan - let line = LineString::from(vec![ + let line: LineString = LineString::from_raw(vec![ coord! { x: 1.0, y: 1.0 }, coord! { x: Float::nan(), @@ -241,7 +241,7 @@ mod test { let pt = point!(x: 2.0, y: 2.0); assert_eq!(line.line_locate_point(&pt), None); - let line = LineString::from(vec![ + let line: LineString = LineString::from_raw(vec![ coord! { x: 1.0, y: 1.0 }, coord! { x: Float::infinity(), @@ -251,7 +251,7 @@ mod test { ]); let pt = point!(x: 2.0, y: 2.0); assert_eq!(line.line_locate_point(&pt), None); - let line = LineString::from(vec![ + let line: LineString = LineString::from_raw(vec![ coord! { x: 1.0, y: 1.0 }, coord! { x: Float::neg_infinity(),