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/for_each.hpp>
11
12 #include <boost/geometry/io/wkt/wkt.hpp>
13
14 #include <boost/geometry/geometries/box.hpp>
15 #include <boost/geometry/geometries/ring.hpp>
16 #include <boost/geometry/geometries/linestring.hpp>
17 #include <boost/geometry/geometries/point.hpp>
18 #include <boost/geometry/geometries/point_xy.hpp>
19 #include <boost/geometry/geometries/polygon.hpp>
20
21 #include <boost/geometry/geometries/multi_point.hpp>
22 #include <boost/geometry/geometries/multi_linestring.hpp>
23 #include <boost/geometry/geometries/multi_polygon.hpp>
24
25 #include <algorithms/test_for_each.hpp>
26
27
28 template <typename P>
test_all()29 void test_all()
30 {
31 test_geometry<bg::model::multi_point<P> >
32 (
33 "MULTIPOINT((1 1))"
34
35 // per point
36 , 1
37 , "MULTIPOINT((101 1))"
38 , "MULTIPOINT((101 100))"
39 // per segment
40 , ""
41 , 0
42 , "MULTIPOINT((1 1))"
43 );
44
45 test_geometry<bg::model::multi_linestring<bg::model::linestring<P> > >
46 (
47 "MULTILINESTRING((1 1,2 2))"
48
49 , 3
50 , "MULTILINESTRING((101 1,102 2))"
51 , "MULTILINESTRING((101 100,102 200))"
52
53 , "((1, 1), (2, 2))"
54 , std::sqrt(2.0)
55 , "MULTILINESTRING((10 1,2 2))"
56 );
57
58 typedef bg::model::multi_polygon<bg::model::polygon<P> > mp;
59 test_geometry<mp>
60 (
61 "MULTIPOLYGON(((1 1,1 4,4 4,4 1,1 1)))"
62
63 , 11
64 , "MULTIPOLYGON(((101 1,101 4,104 4,104 1,101 1)))"
65 , "MULTIPOLYGON(((101 100,101 400,104 400,104 100,101 100)))"
66
67 , "((1, 1), (1, 4)) ((1, 4), (4, 4)) ((4, 4), (4, 1)) ((4, 1), (1, 1))"
68 , 4 * 3.0
69 , "MULTIPOLYGON(((10 1,10 4,4 4,4 1,1 1,10 1)))"
70 );
71
72 // open multipolygon
73 typedef bg::model::multi_polygon<bg::model::polygon<P, true, false> > omp;
74 test_geometry<omp>
75 (
76 "MULTIPOLYGON(((1 1,1 4,4 4,4 1)))"
77
78 , 10
79 , "MULTIPOLYGON(((101 1,101 4,104 4,104 1,101 1)))"
80 , "MULTIPOLYGON(((101 100,101 400,104 400,104 100,101 100)))"
81
82 , "((1, 1), (1, 4)) ((1, 4), (4, 4)) ((4, 4), (4, 1)) ((4, 1), (1, 1))"
83 , 4 * 3.0
84 , "MULTIPOLYGON(((10 1,10 4,4 4,4 1,10 1)))"
85 );
86 }
87
test_main(int,char * [])88 int test_main( int , char* [] )
89 {
90 test_all<bg::model::d2::point_xy<double> >();
91
92 #ifdef HAVE_TTMATH
93 test_all<bg::model::d2::point_xy<ttmath_big> >();
94 #endif
95
96 return 0;
97 }
98