File: has_empty.cpp

package info (click to toggle)
mapnik 3.0.12%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 17,084 kB
  • ctags: 18,454
  • sloc: cpp: 142,516; python: 1,416; sh: 769; makefile: 170; xml: 140; lisp: 13
file content (151 lines) | stat: -rw-r--r-- 4,246 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151

#include "catch.hpp"

#include <mapnik/geometry_is_empty.hpp>

TEST_CASE("geometry has_empty") {

SECTION("empty geometry") {

    mapnik::geometry::geometry_empty geom;
    REQUIRE(!mapnik::geometry::has_empty(geom));
}

SECTION("geometry collection") {

    {
        mapnik::geometry::geometry_collection<double> geom;
        REQUIRE(!mapnik::geometry::has_empty(geom));
    }
    {
        mapnik::geometry::geometry_collection<double> geom;
        mapnik::geometry::geometry_empty geom1;
        geom.emplace_back(std::move(geom1));
        REQUIRE(mapnik::geometry::has_empty(geom));
    }
    {
        mapnik::geometry::geometry_collection<double> geom;
        mapnik::geometry::multi_line_string<double> mls;
        mapnik::geometry::line_string<double> line;
        mls.emplace_back(std::move(line));
        geom.emplace_back(std::move(mls));
        REQUIRE(mapnik::geometry::has_empty(geom));
    }
    {
        mapnik::geometry::geometry_collection<double> geom;
        mapnik::geometry::multi_line_string<double> mls;
        mapnik::geometry::line_string<double> line;
        line.add_coord(0, 0);
        mls.emplace_back(std::move(line));
        geom.emplace_back(std::move(mls));
        REQUIRE(!mapnik::geometry::has_empty(geom));
    }
}

SECTION("point") {

    mapnik::geometry::point<double> pt(10, 10);
    REQUIRE(!mapnik::geometry::has_empty(pt));
}

SECTION("linestring") {

    {
        mapnik::geometry::line_string<double> line;
        REQUIRE(!mapnik::geometry::has_empty(line));
    }
    {
        mapnik::geometry::line_string<double> line;
        line.add_coord(0, 0);
        line.add_coord(25, 25);
        line.add_coord(50, 50);
        REQUIRE(!mapnik::geometry::has_empty(line));
    }
}

SECTION("polygon") {

    {
        mapnik::geometry::polygon<double> poly;
        REQUIRE(!mapnik::geometry::has_empty(poly));
    }
    {
        mapnik::geometry::polygon<double> poly;
        mapnik::geometry::linear_ring<double> ring;
        poly.set_exterior_ring(std::move(ring));
        REQUIRE(!mapnik::geometry::has_empty(poly));
    }
    {
        mapnik::geometry::polygon<double> poly;
        mapnik::geometry::linear_ring<double> ring;
        ring.add_coord(0, 0);
        ring.add_coord(1, 0);
        ring.add_coord(1, 1);
        ring.add_coord(0, 1);
        ring.add_coord(0, 0);
        poly.set_exterior_ring(std::move(ring));
        REQUIRE(!mapnik::geometry::has_empty(poly));
    }
}

SECTION("multi-point") {

    {
        mapnik::geometry::multi_point<double> geom;
        REQUIRE(!mapnik::geometry::has_empty(geom));
    }
    {
        mapnik::geometry::multi_point<double> geom;
        geom.add_coord(0, 0);
        geom.add_coord(25, 25);
        geom.add_coord(50, 50);
        REQUIRE(!mapnik::geometry::has_empty(geom));
    }
}

SECTION("multi-linestring") {

    {
        mapnik::geometry::multi_line_string<double> geom;
        REQUIRE(!mapnik::geometry::has_empty(geom));
    }
    {
        mapnik::geometry::multi_line_string<double> geom;
        mapnik::geometry::line_string<double> line;
        geom.emplace_back(std::move(line));
        REQUIRE(mapnik::geometry::has_empty(geom));
    }
    {
        mapnik::geometry::multi_line_string<double> geom;
        mapnik::geometry::line_string<double> line;
        line.add_coord(0, 0);
        geom.emplace_back(std::move(line));
        REQUIRE(!mapnik::geometry::has_empty(geom));
    }
}

SECTION("multi-polygon") {

    {
        mapnik::geometry::multi_polygon<double> geom;
        REQUIRE(!mapnik::geometry::has_empty(geom));
    }
    {
        mapnik::geometry::multi_polygon<double> geom;
        mapnik::geometry::polygon<double> poly;
        mapnik::geometry::linear_ring<double> ring;
        poly.set_exterior_ring(std::move(ring));
        geom.emplace_back(std::move(poly));
        REQUIRE(mapnik::geometry::has_empty(geom));
    }
    {
        mapnik::geometry::multi_polygon<double> geom;
        mapnik::geometry::polygon<double> poly;
        mapnik::geometry::linear_ring<double> ring;
        ring.add_coord(0, 0);
        poly.set_exterior_ring(std::move(ring));
        geom.emplace_back(std::move(poly));
        REQUIRE(!mapnik::geometry::has_empty(geom));
    }
}
}