1 // Boost.Geometry (aka GGL, Generic Geometry Library)
2 //
3 // Copyright (c) 2007-2015 Barend Gehrels, Amsterdam, the Netherlands.
4 // Use, modification and distribution is subject to the Boost Software License,
5 // Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
6 // http://www.boost.org/LICENSE_1_0.txt)
7
8 #include <geometry_test_common.hpp>
9
10 #include <boost/geometry/algorithms/unique.hpp>
11
12 #include <boost/geometry/geometries/geometries.hpp>
13 #include <boost/geometry/geometries/point_xy.hpp>
14
15 #include <algorithms/test_unique.hpp>
16
17
18 template <typename P>
test_all()19 void test_all()
20 {
21 // Multi point, should happen nothing, even if there are duplicate points
22 test_geometry<bg::model::multi_point<P> >(
23 "MULTIPOINT((0 0),(0 0),(1 1))",
24 "MULTIPOINT((0 0),(0 0),(1 1))");
25
26 test_geometry<bg::model::multi_linestring<bg::model::linestring<P> > >(
27 "MULTILINESTRING((0 0,1 1,1 1),(3 3,3 3,4 4))",
28 "MULTILINESTRING((0 0,1 1),(3 3,4 4))");
29
30 typedef bg::model::multi_polygon<bg::model::polygon<P> > mp;
31 test_geometry<mp>(
32 "MULTIPOLYGON(((0 0,0 1,1 1,1 1,1 1,1 0,0 0,0 0)))",
33 "MULTIPOLYGON(((0 0,0 1,1 1,1 0,0 0)))");
34
35 // With holes
36 test_geometry<mp>(
37 "MULTIPOLYGON(((0 0,0 10,10 10,10 10,10 10,10 0,0 0,0 0)))",
38 "MULTIPOLYGON(((0 0,0 10,10 10,10 0,0 0)))");
39
40 }
41
test_main(int,char * [])42 int test_main( int , char* [] )
43 {
44 test_all<bg::model::d2::point_xy<int> >();
45 test_all<bg::model::d2::point_xy<double> >();
46
47 #ifdef HAVE_TTMATH
48 test_all<bg::model::d2::point_xy<ttmath_big> >();
49 #endif
50
51 return 0;
52 }
53