rgeo 0.3.3 → 0.3.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/History.rdoc +6 -0
- data/README.rdoc +1 -1
- data/Version +1 -1
- data/ext/geos_c_impl/extconf.rb +13 -13
- data/ext/geos_c_impl/factory.c +30 -18
- data/ext/geos_c_impl/factory.h +18 -12
- data/ext/geos_c_impl/geometry.c +11 -11
- data/ext/geos_c_impl/geometry.h +7 -7
- data/ext/geos_c_impl/geometry_collection.c +15 -15
- data/ext/geos_c_impl/geometry_collection.h +8 -8
- data/ext/geos_c_impl/line_string.c +14 -14
- data/ext/geos_c_impl/line_string.h +7 -7
- data/ext/geos_c_impl/main.c +7 -7
- data/ext/geos_c_impl/point.c +9 -9
- data/ext/geos_c_impl/point.h +7 -7
- data/ext/geos_c_impl/polygon.c +9 -9
- data/ext/geos_c_impl/polygon.h +7 -7
- data/ext/geos_c_impl/preface.h +7 -7
- data/ext/proj4_c_impl/extconf.rb +13 -13
- data/ext/proj4_c_impl/main.c +12 -12
- data/lib/rgeo.rb +26 -26
- data/lib/rgeo/cartesian.rb +12 -12
- data/lib/rgeo/cartesian/analysis.rb +26 -26
- data/lib/rgeo/cartesian/bounding_box.rb +83 -83
- data/lib/rgeo/cartesian/calculations.rb +36 -36
- data/lib/rgeo/cartesian/factory.rb +78 -78
- data/lib/rgeo/cartesian/feature_classes.rb +74 -74
- data/lib/rgeo/cartesian/feature_methods.rb +34 -34
- data/lib/rgeo/cartesian/interface.rb +33 -33
- data/lib/rgeo/coord_sys.rb +15 -15
- data/lib/rgeo/coord_sys/cs/entities.rb +533 -534
- data/lib/rgeo/coord_sys/cs/factories.rb +69 -69
- data/lib/rgeo/coord_sys/cs/wkt_parser.rb +44 -44
- data/lib/rgeo/coord_sys/proj4.rb +85 -85
- data/lib/rgeo/coord_sys/srs_database/active_record_table.rb +31 -31
- data/lib/rgeo/coord_sys/srs_database/interface.rb +44 -44
- data/lib/rgeo/coord_sys/srs_database/proj4_data.rb +31 -31
- data/lib/rgeo/coord_sys/srs_database/sr_org.rb +31 -31
- data/lib/rgeo/coord_sys/srs_database/url_reader.rb +29 -29
- data/lib/rgeo/error.rb +17 -17
- data/lib/rgeo/feature.rb +15 -15
- data/lib/rgeo/feature/curve.rb +58 -58
- data/lib/rgeo/feature/factory.rb +84 -84
- data/lib/rgeo/feature/factory_generator.rb +32 -32
- data/lib/rgeo/feature/geometry.rb +215 -215
- data/lib/rgeo/feature/geometry_collection.rb +46 -46
- data/lib/rgeo/feature/line.rb +21 -21
- data/lib/rgeo/feature/line_string.rb +35 -35
- data/lib/rgeo/feature/linear_ring.rb +20 -20
- data/lib/rgeo/feature/mixins.rb +61 -61
- data/lib/rgeo/feature/multi_curve.rb +37 -37
- data/lib/rgeo/feature/multi_line_string.rb +20 -20
- data/lib/rgeo/feature/multi_point.rb +22 -22
- data/lib/rgeo/feature/multi_polygon.rb +28 -28
- data/lib/rgeo/feature/multi_surface.rb +39 -39
- data/lib/rgeo/feature/point.rb +42 -42
- data/lib/rgeo/feature/polygon.rb +50 -50
- data/lib/rgeo/feature/surface.rb +42 -42
- data/lib/rgeo/feature/types.rb +58 -58
- data/lib/rgeo/geographic.rb +14 -14
- data/lib/rgeo/geographic/factory.rb +87 -87
- data/lib/rgeo/geographic/interface.rb +55 -55
- data/lib/rgeo/geographic/proj4_projector.rb +35 -35
- data/lib/rgeo/geographic/projected_feature_classes.rb +95 -95
- data/lib/rgeo/geographic/projected_feature_methods.rb +81 -81
- data/lib/rgeo/geographic/projected_window.rb +103 -103
- data/lib/rgeo/geographic/simple_mercator_projector.rb +32 -32
- data/lib/rgeo/geographic/spherical_feature_classes.rb +93 -93
- data/lib/rgeo/geographic/spherical_feature_methods.rb +25 -25
- data/lib/rgeo/geographic/spherical_math.rb +58 -58
- data/lib/rgeo/geos.rb +22 -17
- data/lib/rgeo/geos/factory.rb +93 -93
- data/lib/rgeo/geos/ffi_classes.rb +306 -231
- data/lib/rgeo/geos/ffi_factory.rb +100 -96
- data/lib/rgeo/geos/impl_additions.rb +22 -22
- data/lib/rgeo/geos/interface.rb +45 -45
- data/lib/rgeo/geos/zm_factory.rb +90 -90
- data/lib/rgeo/geos/zm_impl.rb +167 -167
- data/lib/rgeo/impl_helper.rb +11 -11
- data/lib/rgeo/impl_helper/basic_geometry_collection_methods.rb +71 -71
- data/lib/rgeo/impl_helper/basic_geometry_methods.rb +29 -29
- data/lib/rgeo/impl_helper/basic_line_string_methods.rb +61 -61
- data/lib/rgeo/impl_helper/basic_point_methods.rb +43 -43
- data/lib/rgeo/impl_helper/basic_polygon_methods.rb +35 -35
- data/lib/rgeo/impl_helper/math.rb +13 -13
- data/lib/rgeo/version.rb +10 -10
- data/lib/rgeo/wkrep.rb +16 -16
- data/lib/rgeo/wkrep/wkb_generator.rb +51 -51
- data/lib/rgeo/wkrep/wkb_parser.rb +52 -52
- data/lib/rgeo/wkrep/wkt_generator.rb +51 -51
- data/lib/rgeo/wkrep/wkt_parser.rb +66 -66
- data/lib/rgeo/yaml.rb +14 -14
- data/test/common/geometry_collection_tests.rb +53 -53
- data/test/common/line_string_tests.rb +57 -57
- data/test/common/multi_line_string_tests.rb +43 -43
- data/test/common/multi_point_tests.rb +43 -43
- data/test/common/multi_polygon_tests.rb +43 -43
- data/test/common/point_tests.rb +75 -75
- data/test/common/polygon_tests.rb +37 -37
- data/test/coord_sys/tc_active_record_table.rb +25 -25
- data/test/coord_sys/tc_ogc_cs.rb +72 -72
- data/test/coord_sys/tc_proj4.rb +51 -51
- data/test/coord_sys/tc_proj4_srs_data.rb +17 -17
- data/test/coord_sys/tc_sr_org.rb +15 -15
- data/test/coord_sys/tc_url_reader.rb +19 -19
- data/test/geos_capi/tc_factory.rb +21 -21
- data/test/geos_capi/tc_geometry_collection.rb +15 -15
- data/test/geos_capi/tc_line_string.rb +15 -15
- data/test/geos_capi/tc_misc.rb +33 -22
- data/test/geos_capi/tc_multi_line_string.rb +15 -15
- data/test/geos_capi/tc_multi_point.rb +15 -15
- data/test/geos_capi/tc_multi_polygon.rb +15 -15
- data/test/geos_capi/tc_parsing_unparsing.rb +19 -19
- data/test/geos_capi/tc_point.rb +21 -21
- data/test/geos_capi/tc_polygon.rb +19 -19
- data/test/geos_capi/tc_zmfactory.rb +17 -17
- data/test/geos_ffi/tc_factory.rb +21 -21
- data/test/geos_ffi/tc_geometry_collection.rb +15 -15
- data/test/geos_ffi/tc_line_string.rb +15 -15
- data/test/geos_ffi/tc_misc.rb +49 -15
- data/test/geos_ffi/tc_multi_line_string.rb +15 -15
- data/test/geos_ffi/tc_multi_point.rb +15 -15
- data/test/geos_ffi/tc_multi_polygon.rb +15 -15
- data/test/geos_ffi/tc_parsing_unparsing.rb +19 -19
- data/test/geos_ffi/tc_point.rb +21 -21
- data/test/geos_ffi/tc_polygon.rb +19 -19
- data/test/geos_ffi/tc_zmfactory.rb +17 -17
- data/test/projected_geographic/tc_geometry_collection.rb +15 -15
- data/test/projected_geographic/tc_line_string.rb +15 -15
- data/test/projected_geographic/tc_multi_line_string.rb +15 -15
- data/test/projected_geographic/tc_multi_point.rb +15 -15
- data/test/projected_geographic/tc_multi_polygon.rb +15 -15
- data/test/projected_geographic/tc_point.rb +23 -23
- data/test/projected_geographic/tc_polygon.rb +15 -15
- data/test/simple_cartesian/tc_calculations.rb +31 -31
- data/test/simple_cartesian/tc_geometry_collection.rb +17 -17
- data/test/simple_cartesian/tc_line_string.rb +17 -17
- data/test/simple_cartesian/tc_multi_line_string.rb +17 -17
- data/test/simple_cartesian/tc_multi_point.rb +17 -17
- data/test/simple_cartesian/tc_multi_polygon.rb +17 -17
- data/test/simple_cartesian/tc_point.rb +21 -21
- data/test/simple_cartesian/tc_polygon.rb +17 -17
- data/test/simple_mercator/tc_geometry_collection.rb +15 -15
- data/test/simple_mercator/tc_line_string.rb +15 -15
- data/test/simple_mercator/tc_multi_line_string.rb +15 -15
- data/test/simple_mercator/tc_multi_point.rb +15 -15
- data/test/simple_mercator/tc_multi_polygon.rb +15 -15
- data/test/simple_mercator/tc_point.rb +23 -23
- data/test/simple_mercator/tc_polygon.rb +15 -15
- data/test/simple_mercator/tc_window.rb +50 -50
- data/test/spherical_geographic/tc_calculations.rb +47 -47
- data/test/spherical_geographic/tc_geometry_collection.rb +17 -17
- data/test/spherical_geographic/tc_line_string.rb +17 -17
- data/test/spherical_geographic/tc_multi_line_string.rb +17 -17
- data/test/spherical_geographic/tc_multi_point.rb +17 -17
- data/test/spherical_geographic/tc_multi_polygon.rb +17 -17
- data/test/spherical_geographic/tc_point.rb +23 -23
- data/test/spherical_geographic/tc_polygon.rb +17 -17
- data/test/tc_cartesian_analysis.rb +23 -23
- data/test/tc_mixins.rb +39 -39
- data/test/tc_oneoff.rb +15 -15
- data/test/tc_types.rb +17 -17
- data/test/wkrep/tc_wkb_generator.rb +67 -67
- data/test/wkrep/tc_wkb_parser.rb +73 -73
- data/test/wkrep/tc_wkt_generator.rb +75 -75
- data/test/wkrep/tc_wkt_parser.rb +97 -97
- metadata +3 -3
data/test/common/point_tests.rb
CHANGED
@@ -1,15 +1,15 @@
|
|
1
1
|
# -----------------------------------------------------------------------------
|
2
|
-
#
|
2
|
+
#
|
3
3
|
# Common tests for point implementations
|
4
|
-
#
|
4
|
+
#
|
5
5
|
# -----------------------------------------------------------------------------
|
6
|
-
# Copyright 2010 Daniel Azuma
|
7
|
-
#
|
6
|
+
# Copyright 2010-2012 Daniel Azuma
|
7
|
+
#
|
8
8
|
# All rights reserved.
|
9
|
-
#
|
9
|
+
#
|
10
10
|
# Redistribution and use in source and binary forms, with or without
|
11
11
|
# modification, are permitted provided that the following conditions are met:
|
12
|
-
#
|
12
|
+
#
|
13
13
|
# * Redistributions of source code must retain the above copyright notice,
|
14
14
|
# this list of conditions and the following disclaimer.
|
15
15
|
# * Redistributions in binary form must reproduce the above copyright notice,
|
@@ -18,7 +18,7 @@
|
|
18
18
|
# * Neither the name of the copyright holder, nor the names of any other
|
19
19
|
# contributors to this software, may be used to endorse or promote products
|
20
20
|
# derived from this software without specific prior written permission.
|
21
|
-
#
|
21
|
+
#
|
22
22
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
23
23
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
24
24
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
@@ -40,34 +40,34 @@ require 'rgeo'
|
|
40
40
|
module RGeo
|
41
41
|
module Tests # :nodoc:
|
42
42
|
module Common # :nodoc:
|
43
|
-
|
43
|
+
|
44
44
|
module PointTests # :nodoc:
|
45
|
-
|
46
|
-
|
45
|
+
|
46
|
+
|
47
47
|
def assert_close_enough(p1_, p2_)
|
48
48
|
assert((p1_.x - p2_.x).abs < 0.00000001 && (p1_.y - p2_.y).abs < 0.00000001)
|
49
49
|
end
|
50
|
-
|
51
|
-
|
50
|
+
|
51
|
+
|
52
52
|
def assert_contains_approx(p_, mp_)
|
53
53
|
assert(mp_.any?{ |q_| (p_.x - q_.x).abs < 0.00000001 && (p_.y - q_.y).abs < 0.00000001 })
|
54
54
|
end
|
55
|
-
|
56
|
-
|
55
|
+
|
56
|
+
|
57
57
|
def test_creation
|
58
58
|
point_ = @factory.point(21, -22)
|
59
59
|
assert_equal(21, point_.x)
|
60
60
|
assert_equal(-22, point_.y)
|
61
61
|
end
|
62
|
-
|
63
|
-
|
62
|
+
|
63
|
+
|
64
64
|
def test_wkt_creation
|
65
65
|
point1_ = @factory.parse_wkt('Point (21 -22)')
|
66
66
|
assert_equal(21, point1_.x)
|
67
67
|
assert_equal(-22, point1_.y)
|
68
68
|
end
|
69
|
-
|
70
|
-
|
69
|
+
|
70
|
+
|
71
71
|
def test_clone
|
72
72
|
point1_ = @factory.point(11, 12)
|
73
73
|
point2_ = point1_.clone
|
@@ -77,8 +77,8 @@ module RGeo
|
|
77
77
|
assert_equal(point3_, point4_)
|
78
78
|
assert_not_equal(point2_, point4_)
|
79
79
|
end
|
80
|
-
|
81
|
-
|
80
|
+
|
81
|
+
|
82
82
|
def test_type_check
|
83
83
|
point_ = @factory.point(21, 22)
|
84
84
|
assert(::RGeo::Feature::Geometry.check_type(point_))
|
@@ -86,67 +86,67 @@ module RGeo
|
|
86
86
|
assert(!::RGeo::Feature::GeometryCollection.check_type(point_))
|
87
87
|
assert(!::RGeo::Feature::Curve.check_type(point_))
|
88
88
|
end
|
89
|
-
|
90
|
-
|
89
|
+
|
90
|
+
|
91
91
|
def test_geometry_type
|
92
92
|
point_ = @factory.point(11, 12)
|
93
93
|
assert_equal(::RGeo::Feature::Point, point_.geometry_type)
|
94
94
|
end
|
95
|
-
|
96
|
-
|
95
|
+
|
96
|
+
|
97
97
|
def test_dimension
|
98
98
|
point_ = @factory.point(11, 12)
|
99
99
|
assert_equal(0, point_.dimension)
|
100
100
|
end
|
101
|
-
|
102
|
-
|
101
|
+
|
102
|
+
|
103
103
|
def test_envelope
|
104
104
|
point_ = @factory.point(11, 12)
|
105
105
|
assert_close_enough(point_, point_.envelope)
|
106
106
|
end
|
107
|
-
|
108
|
-
|
107
|
+
|
108
|
+
|
109
109
|
def test_as_text
|
110
110
|
point_ = @factory.point(11, 12)
|
111
111
|
assert_equal('POINT (11.0 12.0)', point_.as_text)
|
112
112
|
end
|
113
|
-
|
114
|
-
|
113
|
+
|
114
|
+
|
115
115
|
def test_as_text_wkt_round_trip
|
116
116
|
point1_ = @factory.point(11, 12)
|
117
117
|
text_ = point1_.as_text
|
118
118
|
point2_ = @factory.parse_wkt(text_)
|
119
119
|
assert_equal(point2_, point1_)
|
120
120
|
end
|
121
|
-
|
122
|
-
|
121
|
+
|
122
|
+
|
123
123
|
def test_as_binary_wkb_round_trip
|
124
124
|
point1_ = @factory.point(211, 12)
|
125
125
|
binary_ = point1_.as_binary
|
126
126
|
point2_ = @factory.parse_wkb(binary_)
|
127
127
|
assert_equal(point2_, point1_)
|
128
128
|
end
|
129
|
-
|
130
|
-
|
129
|
+
|
130
|
+
|
131
131
|
def test_is_empty
|
132
132
|
point1_ = @factory.point(0, 0)
|
133
133
|
assert(!point1_.is_empty?)
|
134
134
|
end
|
135
|
-
|
136
|
-
|
135
|
+
|
136
|
+
|
137
137
|
def test_is_simple
|
138
138
|
point1_ = @factory.point(0, 0)
|
139
139
|
assert(point1_.is_simple?)
|
140
140
|
end
|
141
|
-
|
142
|
-
|
141
|
+
|
142
|
+
|
143
143
|
def test_boundary
|
144
144
|
point_ = @factory.point(11, 12)
|
145
145
|
boundary_ = point_.boundary
|
146
146
|
assert(boundary_.is_empty?)
|
147
147
|
end
|
148
|
-
|
149
|
-
|
148
|
+
|
149
|
+
|
150
150
|
def test_equals
|
151
151
|
point1_ = @factory.point(11, 12)
|
152
152
|
point2_ = @factory.point(11, 12)
|
@@ -160,8 +160,8 @@ module RGeo
|
|
160
160
|
assert(point1_ != 'hello')
|
161
161
|
assert(!point1_.eql?('hello'))
|
162
162
|
end
|
163
|
-
|
164
|
-
|
163
|
+
|
164
|
+
|
165
165
|
def test_disjoint
|
166
166
|
point1_ = @factory.point(11, 12)
|
167
167
|
point2_ = @factory.point(11, 12)
|
@@ -169,8 +169,8 @@ module RGeo
|
|
169
169
|
assert(!point1_.disjoint?(point2_))
|
170
170
|
assert(point1_.disjoint?(point3_))
|
171
171
|
end
|
172
|
-
|
173
|
-
|
172
|
+
|
173
|
+
|
174
174
|
def test_intersects
|
175
175
|
point1_ = @factory.point(11, 12)
|
176
176
|
point2_ = @factory.point(11, 12)
|
@@ -178,8 +178,8 @@ module RGeo
|
|
178
178
|
assert(point1_.intersects?(point2_))
|
179
179
|
assert(!point1_.intersects?(point3_))
|
180
180
|
end
|
181
|
-
|
182
|
-
|
181
|
+
|
182
|
+
|
183
183
|
def test_touches
|
184
184
|
point1_ = @factory.point(11, 12)
|
185
185
|
point2_ = @factory.point(11, 12)
|
@@ -187,8 +187,8 @@ module RGeo
|
|
187
187
|
assert(!point1_.touches?(point2_))
|
188
188
|
assert(!point1_.touches?(point3_))
|
189
189
|
end
|
190
|
-
|
191
|
-
|
190
|
+
|
191
|
+
|
192
192
|
def test_crosses
|
193
193
|
point1_ = @factory.point(11, 12)
|
194
194
|
point2_ = @factory.point(11, 12)
|
@@ -196,8 +196,8 @@ module RGeo
|
|
196
196
|
assert(!point1_.crosses?(point2_))
|
197
197
|
assert(!point1_.crosses?(point3_))
|
198
198
|
end
|
199
|
-
|
200
|
-
|
199
|
+
|
200
|
+
|
201
201
|
def test_within
|
202
202
|
point1_ = @factory.point(11, 12)
|
203
203
|
point2_ = @factory.point(11, 12)
|
@@ -205,8 +205,8 @@ module RGeo
|
|
205
205
|
assert(point1_.within?(point2_))
|
206
206
|
assert(!point1_.within?(point3_))
|
207
207
|
end
|
208
|
-
|
209
|
-
|
208
|
+
|
209
|
+
|
210
210
|
def test_contains
|
211
211
|
point1_ = @factory.point(11, 12)
|
212
212
|
point2_ = @factory.point(11, 12)
|
@@ -214,8 +214,8 @@ module RGeo
|
|
214
214
|
assert(point1_.contains?(point2_))
|
215
215
|
assert(!point1_.contains?(point3_))
|
216
216
|
end
|
217
|
-
|
218
|
-
|
217
|
+
|
218
|
+
|
219
219
|
def test_overlaps
|
220
220
|
point1_ = @factory.point(11, 12)
|
221
221
|
point2_ = @factory.point(11, 12)
|
@@ -223,14 +223,14 @@ module RGeo
|
|
223
223
|
assert(!point1_.overlaps?(point2_))
|
224
224
|
assert(!point1_.overlaps?(point3_))
|
225
225
|
end
|
226
|
-
|
227
|
-
|
226
|
+
|
227
|
+
|
228
228
|
def test_convex_hull
|
229
229
|
point_ = @factory.point(11, 12)
|
230
230
|
assert_close_enough(point_, point_.convex_hull)
|
231
231
|
end
|
232
|
-
|
233
|
-
|
232
|
+
|
233
|
+
|
234
234
|
def test_intersection
|
235
235
|
point1_ = @factory.point(11, 12)
|
236
236
|
point2_ = @factory.point(11, 12)
|
@@ -239,8 +239,8 @@ module RGeo
|
|
239
239
|
int13_ = point1_.intersection(point3_)
|
240
240
|
assert(int13_.is_empty?)
|
241
241
|
end
|
242
|
-
|
243
|
-
|
242
|
+
|
243
|
+
|
244
244
|
def test_union
|
245
245
|
point1_ = @factory.point(11, 12)
|
246
246
|
point2_ = @factory.point(11, 12)
|
@@ -252,8 +252,8 @@ module RGeo
|
|
252
252
|
assert_contains_approx(point1_, union13_)
|
253
253
|
assert_contains_approx(point3_, union13_)
|
254
254
|
end
|
255
|
-
|
256
|
-
|
255
|
+
|
256
|
+
|
257
257
|
def test_difference
|
258
258
|
point1_ = @factory.point(11, 12)
|
259
259
|
point2_ = @factory.point(11, 12)
|
@@ -264,8 +264,8 @@ module RGeo
|
|
264
264
|
assert(diff12_.is_empty?)
|
265
265
|
assert_close_enough(point1_, diff13_)
|
266
266
|
end
|
267
|
-
|
268
|
-
|
267
|
+
|
268
|
+
|
269
269
|
def test_sym_difference
|
270
270
|
point1_ = @factory.point(11, 12)
|
271
271
|
point2_ = @factory.point(11, 12)
|
@@ -278,8 +278,8 @@ module RGeo
|
|
278
278
|
assert_contains_approx(point1_, diff13_)
|
279
279
|
assert_contains_approx(point3_, diff13_)
|
280
280
|
end
|
281
|
-
|
282
|
-
|
281
|
+
|
282
|
+
|
283
283
|
def test_3dz_creation
|
284
284
|
point_ = @zfactory.point(11, 12, 13)
|
285
285
|
assert_equal(11, point_.x)
|
@@ -290,8 +290,8 @@ module RGeo
|
|
290
290
|
assert_equal(22, point2_.y)
|
291
291
|
assert_equal(0, point2_.z)
|
292
292
|
end
|
293
|
-
|
294
|
-
|
293
|
+
|
294
|
+
|
295
295
|
def test_3dm_creation
|
296
296
|
point_ = @mfactory.point(11, 12, 13)
|
297
297
|
assert_equal(11, point_.x)
|
@@ -302,8 +302,8 @@ module RGeo
|
|
302
302
|
assert_equal(22, point2_.y)
|
303
303
|
assert_equal(0, point2_.m)
|
304
304
|
end
|
305
|
-
|
306
|
-
|
305
|
+
|
306
|
+
|
307
307
|
def test_4d_creation
|
308
308
|
point_ = @zmfactory.point(11, 12, 13, 14)
|
309
309
|
assert_equal(11, point_.x)
|
@@ -316,8 +316,8 @@ module RGeo
|
|
316
316
|
assert_equal(0, point2_.z)
|
317
317
|
assert_equal(0, point2_.m)
|
318
318
|
end
|
319
|
-
|
320
|
-
|
319
|
+
|
320
|
+
|
321
321
|
def test_wkt_creation_3d
|
322
322
|
point2_ = @zfactory.parse_wkt('POINT(11 12 13)')
|
323
323
|
assert_equal(11, point2_.x)
|
@@ -330,10 +330,10 @@ module RGeo
|
|
330
330
|
# We'd like to define it to be 0, but the GEOS
|
331
331
|
# parser doesn't behave that way.
|
332
332
|
end
|
333
|
-
|
334
|
-
|
333
|
+
|
334
|
+
|
335
335
|
end
|
336
|
-
|
336
|
+
|
337
337
|
end
|
338
338
|
end
|
339
339
|
end
|
@@ -1,15 +1,15 @@
|
|
1
1
|
# -----------------------------------------------------------------------------
|
2
|
-
#
|
2
|
+
#
|
3
3
|
# Common tests for polygon implementations
|
4
|
-
#
|
4
|
+
#
|
5
5
|
# -----------------------------------------------------------------------------
|
6
|
-
# Copyright 2010 Daniel Azuma
|
7
|
-
#
|
6
|
+
# Copyright 2010-2012 Daniel Azuma
|
7
|
+
#
|
8
8
|
# All rights reserved.
|
9
|
-
#
|
9
|
+
#
|
10
10
|
# Redistribution and use in source and binary forms, with or without
|
11
11
|
# modification, are permitted provided that the following conditions are met:
|
12
|
-
#
|
12
|
+
#
|
13
13
|
# * Redistributions of source code must retain the above copyright notice,
|
14
14
|
# this list of conditions and the following disclaimer.
|
15
15
|
# * Redistributions in binary form must reproduce the above copyright notice,
|
@@ -18,7 +18,7 @@
|
|
18
18
|
# * Neither the name of the copyright holder, nor the names of any other
|
19
19
|
# contributors to this software, may be used to endorse or promote products
|
20
20
|
# derived from this software without specific prior written permission.
|
21
|
-
#
|
21
|
+
#
|
22
22
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
23
23
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
24
24
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
@@ -40,10 +40,10 @@ require 'rgeo'
|
|
40
40
|
module RGeo
|
41
41
|
module Tests # :nodoc:
|
42
42
|
module Common # :nodoc:
|
43
|
-
|
43
|
+
|
44
44
|
module PolygonTests # :nodoc:
|
45
|
-
|
46
|
-
|
45
|
+
|
46
|
+
|
47
47
|
def test_creation_simple
|
48
48
|
point1_ = @factory.point(0, 0)
|
49
49
|
point2_ = @factory.point(0, 1)
|
@@ -58,8 +58,8 @@ module RGeo
|
|
58
58
|
assert_nil(polygon_.interior_ring_n(0))
|
59
59
|
assert_nil(polygon_.interior_ring_n(-1))
|
60
60
|
end
|
61
|
-
|
62
|
-
|
61
|
+
|
62
|
+
|
63
63
|
def test_creation_one_hole
|
64
64
|
point1_ = @factory.point(0, 0)
|
65
65
|
point2_ = @factory.point(0, 10)
|
@@ -80,8 +80,8 @@ module RGeo
|
|
80
80
|
assert_nil(polygon_.interior_ring_n(1))
|
81
81
|
assert_nil(polygon_.interior_ring_n(-1))
|
82
82
|
end
|
83
|
-
|
84
|
-
|
83
|
+
|
84
|
+
|
85
85
|
def test_fully_equal
|
86
86
|
point1_ = @factory.point(0, 0)
|
87
87
|
point2_ = @factory.point(0, 1)
|
@@ -96,8 +96,8 @@ module RGeo
|
|
96
96
|
assert(poly1_.eql?(poly2_))
|
97
97
|
assert(poly1_.equals?(poly2_))
|
98
98
|
end
|
99
|
-
|
100
|
-
|
99
|
+
|
100
|
+
|
101
101
|
def test_geometrically_equal_but_ordered_different
|
102
102
|
point1_ = @factory.point(0, 0)
|
103
103
|
point2_ = @factory.point(0, 1)
|
@@ -109,8 +109,8 @@ module RGeo
|
|
109
109
|
assert(!poly1_.eql?(poly2_))
|
110
110
|
assert(poly1_.equals?(poly2_))
|
111
111
|
end
|
112
|
-
|
113
|
-
|
112
|
+
|
113
|
+
|
114
114
|
def test_geometrically_equal_but_different_directions
|
115
115
|
point1_ = @factory.point(0, 0)
|
116
116
|
point2_ = @factory.point(0, 1)
|
@@ -122,8 +122,8 @@ module RGeo
|
|
122
122
|
assert(!poly1_.eql?(poly2_))
|
123
123
|
assert(poly1_.equals?(poly2_))
|
124
124
|
end
|
125
|
-
|
126
|
-
|
125
|
+
|
126
|
+
|
127
127
|
def test_wkt_creation_simple
|
128
128
|
parsed_poly_ = @factory.parse_wkt('POLYGON((0 0, 0 1, 1 0, 0 0))')
|
129
129
|
point1_ = @factory.point(0, 0)
|
@@ -133,8 +133,8 @@ module RGeo
|
|
133
133
|
built_poly_ = @factory.polygon(exterior_)
|
134
134
|
assert(built_poly_.eql?(parsed_poly_))
|
135
135
|
end
|
136
|
-
|
137
|
-
|
136
|
+
|
137
|
+
|
138
138
|
def test_wkt_creation_one_hole
|
139
139
|
parsed_poly_ = @factory.parse_wkt('POLYGON((0 0, 0 10, 10 10, 10 0, 0 0), (4 4, 5 6, 6 4, 4 4))')
|
140
140
|
point1_ = @factory.point(0, 0)
|
@@ -149,8 +149,8 @@ module RGeo
|
|
149
149
|
built_poly_ = @factory.polygon(exterior_, [interior_])
|
150
150
|
assert(built_poly_.eql?(parsed_poly_))
|
151
151
|
end
|
152
|
-
|
153
|
-
|
152
|
+
|
153
|
+
|
154
154
|
def test_clone
|
155
155
|
point1_ = @factory.point(0, 0)
|
156
156
|
point2_ = @factory.point(0, 1)
|
@@ -162,8 +162,8 @@ module RGeo
|
|
162
162
|
assert(exterior_.eql?(poly2_.exterior_ring))
|
163
163
|
assert_equal(0, poly2_.num_interior_rings)
|
164
164
|
end
|
165
|
-
|
166
|
-
|
165
|
+
|
166
|
+
|
167
167
|
def test_type_check
|
168
168
|
point1_ = @factory.point(0, 0)
|
169
169
|
point2_ = @factory.point(0, 1)
|
@@ -176,8 +176,8 @@ module RGeo
|
|
176
176
|
assert(::RGeo::Feature::Surface.check_type(poly_))
|
177
177
|
assert(::RGeo::Feature::Polygon.check_type(poly_))
|
178
178
|
end
|
179
|
-
|
180
|
-
|
179
|
+
|
180
|
+
|
181
181
|
def test_as_text_wkt_round_trip
|
182
182
|
point1_ = @factory.point(0, 0)
|
183
183
|
point2_ = @factory.point(0, 1)
|
@@ -188,8 +188,8 @@ module RGeo
|
|
188
188
|
poly2_ = @factory.parse_wkt(text_)
|
189
189
|
assert(poly1_.eql?(poly2_))
|
190
190
|
end
|
191
|
-
|
192
|
-
|
191
|
+
|
192
|
+
|
193
193
|
def test_as_binary_wkb_round_trip
|
194
194
|
point1_ = @factory.point(0, 0)
|
195
195
|
point2_ = @factory.point(0, 1)
|
@@ -200,8 +200,8 @@ module RGeo
|
|
200
200
|
poly2_ = @factory.parse_wkb(binary_)
|
201
201
|
assert(poly1_.eql?(poly2_))
|
202
202
|
end
|
203
|
-
|
204
|
-
|
203
|
+
|
204
|
+
|
205
205
|
def test_dimension
|
206
206
|
point1_ = @factory.point(0, 0)
|
207
207
|
point2_ = @factory.point(0, 10)
|
@@ -215,8 +215,8 @@ module RGeo
|
|
215
215
|
poly_ = @factory.polygon(exterior_, [interior_])
|
216
216
|
assert_equal(2, poly_.dimension)
|
217
217
|
end
|
218
|
-
|
219
|
-
|
218
|
+
|
219
|
+
|
220
220
|
def test_is_empty
|
221
221
|
point1_ = @factory.point(0, 0)
|
222
222
|
point2_ = @factory.point(0, 1)
|
@@ -227,10 +227,10 @@ module RGeo
|
|
227
227
|
poly2_ = @factory.polygon(@factory.linear_ring([]))
|
228
228
|
assert(poly2_.is_empty?)
|
229
229
|
end
|
230
|
-
|
231
|
-
|
230
|
+
|
231
|
+
|
232
232
|
end
|
233
|
-
|
233
|
+
|
234
234
|
end
|
235
235
|
end
|
236
236
|
end
|