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/lib/rgeo/geos/interface.rb
CHANGED
@@ -1,15 +1,15 @@
|
|
1
1
|
# -----------------------------------------------------------------------------
|
2
|
-
#
|
2
|
+
#
|
3
3
|
# GEOS toplevel interface
|
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
|
@@ -35,89 +35,89 @@
|
|
35
35
|
|
36
36
|
|
37
37
|
module RGeo
|
38
|
-
|
38
|
+
|
39
39
|
module Geos
|
40
|
-
|
40
|
+
|
41
41
|
class << self
|
42
|
-
|
43
|
-
|
42
|
+
|
43
|
+
|
44
44
|
# Returns true if CAPI GEOS implementation is supported.
|
45
|
-
|
45
|
+
|
46
46
|
def capi_supported?
|
47
47
|
CAPI_SUPPORTED
|
48
48
|
end
|
49
|
-
|
50
|
-
|
49
|
+
|
50
|
+
|
51
51
|
# Returns true if FFI GEOS implementation is supported.
|
52
|
-
|
52
|
+
|
53
53
|
def ffi_supported?
|
54
54
|
FFI_SUPPORTED
|
55
55
|
end
|
56
|
-
|
57
|
-
|
56
|
+
|
57
|
+
|
58
58
|
# Returns true if any GEOS implementation is supported.
|
59
59
|
# If this returns false, GEOS features are not available at all.
|
60
|
-
|
60
|
+
|
61
61
|
def supported?
|
62
62
|
FFI_SUPPORTED || CAPI_SUPPORTED
|
63
63
|
end
|
64
|
-
|
65
|
-
|
64
|
+
|
65
|
+
|
66
66
|
# Returns true if the given feature is a CAPI GEOS feature, or if
|
67
67
|
# the given factory is a CAPI GEOS factory.
|
68
|
-
|
68
|
+
|
69
69
|
def is_capi_geos?(object_)
|
70
70
|
Factory === object_ || GeometryImpl === object_ ||
|
71
71
|
ZMFactory === object_ && Factory === object_.z_factory ||
|
72
72
|
ZMGeometryImpl === object_ && GeometryImpl === object_.z_geometry
|
73
73
|
end
|
74
|
-
|
75
|
-
|
74
|
+
|
75
|
+
|
76
76
|
# Returns true if the given feature is an FFI GEOS feature, or if
|
77
77
|
# the given factory is an FFI GEOS factory.
|
78
|
-
|
78
|
+
|
79
79
|
def is_ffi_geos?(object_)
|
80
80
|
FFIFactory === object_ || FFIGeometryImpl === object_ ||
|
81
81
|
ZMFactory === object_ && FFIFactory === object_.z_factory ||
|
82
82
|
ZMGeometryImpl === object_ && FFIGeometryImpl === object_.z_geometry
|
83
83
|
end
|
84
|
-
|
85
|
-
|
84
|
+
|
85
|
+
|
86
86
|
# Returns true if the given feature is a GEOS feature, or if the given
|
87
87
|
# factory is a GEOS factory. Does not distinguish between CAPI and FFI.
|
88
|
-
|
88
|
+
|
89
89
|
def is_geos?(object_)
|
90
90
|
Factory === object_ || GeometryImpl === object_ ||
|
91
91
|
FFIFactory === object_ || FFIGeometryImpl === object_ ||
|
92
92
|
ZMFactory === object_ || ZMGeometryImpl === object_
|
93
93
|
end
|
94
|
-
|
95
|
-
|
94
|
+
|
95
|
+
|
96
96
|
# The preferred native interface. This is the native interface
|
97
97
|
# used by default when a factory is created.
|
98
98
|
# Supported values are <tt>:capi</tt> and <tt>:ffi</tt>.
|
99
|
-
#
|
99
|
+
#
|
100
100
|
# This is set automatically when RGeo loads, to <tt>:capi</tt>
|
101
101
|
# if the CAPI interface is available, otheriwse to <tt>:ffi</tt>
|
102
102
|
# if FFI is available, otherwise to nil if no GEOS interface is
|
103
103
|
# available. You can override this setting if you want to prefer
|
104
104
|
# FFI over CAPI.
|
105
|
-
|
105
|
+
|
106
106
|
attr_accessor :preferred_native_interface
|
107
|
-
|
108
|
-
|
107
|
+
|
108
|
+
|
109
109
|
# Returns a factory for the GEOS implementation.
|
110
110
|
# Returns nil if the GEOS implementation is not supported.
|
111
|
-
#
|
111
|
+
#
|
112
112
|
# Note that GEOS does not natively support 4-dimensional data
|
113
113
|
# (i.e. both z and m values). However, RGeo's GEOS wrapper does
|
114
114
|
# provide a 4-dimensional factory that utilizes an extra native
|
115
115
|
# GEOS object to handle the extra coordinate. Hence, a factory
|
116
116
|
# configured with both Z and M support will work, but will be
|
117
117
|
# slower than a 2-dimensional or 3-dimensional factory.
|
118
|
-
#
|
118
|
+
#
|
119
119
|
# Options include:
|
120
|
-
#
|
120
|
+
#
|
121
121
|
# [<tt>:native_interface</tt>]
|
122
122
|
# Specifies which native interface to use. Possible values are
|
123
123
|
# <tt>:capi</tt> and <tt>:ffi</tt>. The default is the value
|
@@ -197,7 +197,7 @@ module RGeo
|
|
197
197
|
# generate one explicitly using the <tt>prepare!</tt> method).
|
198
198
|
# Currently, prepared geometries are supported under CAPI but
|
199
199
|
# not FFI.
|
200
|
-
|
200
|
+
|
201
201
|
def factory(opts_={})
|
202
202
|
if supported?
|
203
203
|
native_interface_ = opts_[:native_interface] || Geos.preferred_native_interface
|
@@ -212,23 +212,23 @@ module RGeo
|
|
212
212
|
nil
|
213
213
|
end
|
214
214
|
end
|
215
|
-
|
216
|
-
|
215
|
+
|
216
|
+
|
217
217
|
# Returns a Feature::FactoryGenerator that creates Geos-backed
|
218
218
|
# factories. The given options are used as the default options.
|
219
|
-
#
|
219
|
+
#
|
220
220
|
# A common case for this is to provide the <tt>:srs_database</tt>
|
221
221
|
# as a default. Then, the factory generator need only be passed
|
222
222
|
# an SRID and it will automatically fetch the appropriate Proj4
|
223
223
|
# and CoordSys objects.
|
224
|
-
|
224
|
+
|
225
225
|
def factory_generator(defaults_={})
|
226
226
|
::Proc.new{ |c_| factory(defaults_.merge(c_)) }
|
227
227
|
end
|
228
|
-
|
229
|
-
|
228
|
+
|
229
|
+
|
230
230
|
end
|
231
|
-
|
231
|
+
|
232
232
|
end
|
233
|
-
|
233
|
+
|
234
234
|
end
|
data/lib/rgeo/geos/zm_factory.rb
CHANGED
@@ -1,15 +1,15 @@
|
|
1
1
|
# -----------------------------------------------------------------------------
|
2
|
-
#
|
2
|
+
#
|
3
3
|
# GEOS zm factory implementation
|
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
|
@@ -35,32 +35,32 @@
|
|
35
35
|
|
36
36
|
|
37
37
|
module RGeo
|
38
|
-
|
38
|
+
|
39
39
|
module Geos
|
40
|
-
|
41
|
-
|
40
|
+
|
41
|
+
|
42
42
|
# A factory for Geos that handles both Z and M.
|
43
|
-
|
43
|
+
|
44
44
|
class ZMFactory
|
45
|
-
|
45
|
+
|
46
46
|
include Feature::Factory::Instance
|
47
|
-
|
48
|
-
|
47
|
+
|
48
|
+
|
49
49
|
class << self
|
50
|
-
|
51
|
-
|
50
|
+
|
51
|
+
|
52
52
|
# Create a new factory. Returns nil if the GEOS implementation is
|
53
53
|
# not supported.
|
54
|
-
|
54
|
+
|
55
55
|
def create(opts_={})
|
56
56
|
return nil unless Geos.supported?
|
57
57
|
new(opts_)
|
58
58
|
end
|
59
|
-
|
60
|
-
|
59
|
+
|
60
|
+
|
61
61
|
end
|
62
|
-
|
63
|
-
|
62
|
+
|
63
|
+
|
64
64
|
def initialize(opts_={}) # :nodoc:
|
65
65
|
proj4_ = opts_[:proj4]
|
66
66
|
coord_sys_ = opts_[:coord_sys]
|
@@ -88,7 +88,7 @@ module RGeo
|
|
88
88
|
@zfactory = Factory.create(config_.merge(:has_z_coordinate => true))
|
89
89
|
@mfactory = Factory.create(config_.merge(:has_m_coordinate => true))
|
90
90
|
end
|
91
|
-
|
91
|
+
|
92
92
|
wkt_generator_ = opts_[:wkt_generator]
|
93
93
|
case wkt_generator_
|
94
94
|
when ::Hash
|
@@ -118,54 +118,54 @@ module RGeo
|
|
118
118
|
@wkb_parser = WKRep::WKBParser.new(self)
|
119
119
|
end
|
120
120
|
end
|
121
|
-
|
122
|
-
|
121
|
+
|
122
|
+
|
123
123
|
# Returns the SRID of geometries created by this factory.
|
124
|
-
|
124
|
+
|
125
125
|
def srid
|
126
126
|
@zfactory.srid
|
127
127
|
end
|
128
|
-
|
129
|
-
|
128
|
+
|
129
|
+
|
130
130
|
# Returns the resolution used by buffer calculations on geometries
|
131
131
|
# created by this factory
|
132
|
-
|
132
|
+
|
133
133
|
def buffer_resolution
|
134
134
|
@zfactory.buffer_resolution
|
135
135
|
end
|
136
|
-
|
137
|
-
|
136
|
+
|
137
|
+
|
138
138
|
# Returns true if this factory is lenient with MultiPolygon assertions
|
139
|
-
|
139
|
+
|
140
140
|
def lenient_multi_polygon_assertions?
|
141
141
|
@zfactory.lenient_multi_polygon_assertions?
|
142
142
|
end
|
143
|
-
|
144
|
-
|
143
|
+
|
144
|
+
|
145
145
|
# Returns the z-only factory corresponding to this factory.
|
146
|
-
|
146
|
+
|
147
147
|
def z_factory
|
148
148
|
@zfactory
|
149
149
|
end
|
150
|
-
|
151
|
-
|
150
|
+
|
151
|
+
|
152
152
|
# Returns the m-only factory corresponding to this factory.
|
153
|
-
|
153
|
+
|
154
154
|
def m_factory
|
155
155
|
@mfactory
|
156
156
|
end
|
157
|
-
|
158
|
-
|
157
|
+
|
158
|
+
|
159
159
|
# Factory equivalence test.
|
160
|
-
|
160
|
+
|
161
161
|
def eql?(rhs_)
|
162
162
|
rhs_.is_a?(ZMFactory) && rhs_.z_factory == @zfactory
|
163
163
|
end
|
164
164
|
alias_method :==, :eql?
|
165
|
-
|
166
|
-
|
165
|
+
|
166
|
+
|
167
167
|
# See ::RGeo::Feature::Factory#property
|
168
|
-
|
168
|
+
|
169
169
|
def property(name_)
|
170
170
|
case name_
|
171
171
|
when :has_z_coordinate, :has_m_coordinate, :is_cartesian
|
@@ -174,101 +174,101 @@ module RGeo
|
|
174
174
|
nil
|
175
175
|
end
|
176
176
|
end
|
177
|
-
|
178
|
-
|
177
|
+
|
178
|
+
|
179
179
|
# See ::RGeo::Feature::Factory#parse_wkt
|
180
|
-
|
180
|
+
|
181
181
|
def parse_wkt(str_)
|
182
182
|
@wkt_parser.parse(str_)
|
183
183
|
end
|
184
|
-
|
185
|
-
|
184
|
+
|
185
|
+
|
186
186
|
# See ::RGeo::Feature::Factory#parse_wkb
|
187
|
-
|
187
|
+
|
188
188
|
def parse_wkb(str_)
|
189
189
|
@wkb_parser.parse(str_)
|
190
190
|
end
|
191
|
-
|
192
|
-
|
191
|
+
|
192
|
+
|
193
193
|
# See ::RGeo::Feature::Factory#point
|
194
|
-
|
194
|
+
|
195
195
|
def point(x_, y_, z_=0, m_=0)
|
196
196
|
ZMPointImpl.create(self, @zfactory.point(x_, y_, z_), @mfactory.point(x_, y_, m_))
|
197
197
|
end
|
198
|
-
|
199
|
-
|
198
|
+
|
199
|
+
|
200
200
|
# See ::RGeo::Feature::Factory#line_string
|
201
|
-
|
201
|
+
|
202
202
|
def line_string(points_)
|
203
203
|
ZMLineStringImpl.create(self, @zfactory.line_string(points_), @mfactory.line_string(points_))
|
204
204
|
end
|
205
|
-
|
206
|
-
|
205
|
+
|
206
|
+
|
207
207
|
# See ::RGeo::Feature::Factory#line
|
208
|
-
|
208
|
+
|
209
209
|
def line(start_, end_)
|
210
210
|
ZMLineStringImpl.create(self, @zfactory.line(start_, end_), @mfactory.line(start_, end_))
|
211
211
|
end
|
212
|
-
|
213
|
-
|
212
|
+
|
213
|
+
|
214
214
|
# See ::RGeo::Feature::Factory#linear_ring
|
215
|
-
|
215
|
+
|
216
216
|
def linear_ring(points_)
|
217
217
|
ZMLineStringImpl.create(self, @zfactory.linear_ring(points_), @mfactory.linear_ring(points_))
|
218
218
|
end
|
219
|
-
|
220
|
-
|
219
|
+
|
220
|
+
|
221
221
|
# See ::RGeo::Feature::Factory#polygon
|
222
|
-
|
222
|
+
|
223
223
|
def polygon(outer_ring_, inner_rings_=nil)
|
224
224
|
ZMPolygonImpl.create(self, @zfactory.polygon(outer_ring_, inner_rings_), @mfactory.polygon(outer_ring_, inner_rings_))
|
225
225
|
end
|
226
|
-
|
227
|
-
|
226
|
+
|
227
|
+
|
228
228
|
# See ::RGeo::Feature::Factory#collection
|
229
|
-
|
229
|
+
|
230
230
|
def collection(elems_)
|
231
231
|
ZMGeometryCollectionImpl.create(self, @zfactory.collection(elems_), @mfactory.collection(elems_))
|
232
232
|
end
|
233
|
-
|
234
|
-
|
233
|
+
|
234
|
+
|
235
235
|
# See ::RGeo::Feature::Factory#multi_point
|
236
|
-
|
236
|
+
|
237
237
|
def multi_point(elems_)
|
238
238
|
ZMGeometryCollectionImpl.create(self, @zfactory.multi_point(elems_), @mfactory.multi_point(elems_))
|
239
239
|
end
|
240
|
-
|
241
|
-
|
240
|
+
|
241
|
+
|
242
242
|
# See ::RGeo::Feature::Factory#multi_line_string
|
243
|
-
|
243
|
+
|
244
244
|
def multi_line_string(elems_)
|
245
245
|
ZMMultiLineStringImpl.create(self, @zfactory.multi_line_string(elems_), @mfactory.multi_line_string(elems_))
|
246
246
|
end
|
247
|
-
|
248
|
-
|
247
|
+
|
248
|
+
|
249
249
|
# See ::RGeo::Feature::Factory#multi_polygon
|
250
|
-
|
250
|
+
|
251
251
|
def multi_polygon(elems_)
|
252
252
|
ZMMultiPolygonImpl.create(self, @zfactory.multi_polygon(elems_), @mfactory.multi_polygon(elems_))
|
253
253
|
end
|
254
|
-
|
255
|
-
|
254
|
+
|
255
|
+
|
256
256
|
# See ::RGeo::Feature::Factory#proj4
|
257
|
-
|
257
|
+
|
258
258
|
def proj4
|
259
259
|
@zfactory.proj4
|
260
260
|
end
|
261
|
-
|
262
|
-
|
261
|
+
|
262
|
+
|
263
263
|
# See ::RGeo::Feature::Factory#coord_sys
|
264
|
-
|
264
|
+
|
265
265
|
def coord_sys
|
266
266
|
@zfactory.coord_sys
|
267
267
|
end
|
268
|
-
|
269
|
-
|
268
|
+
|
269
|
+
|
270
270
|
# See ::RGeo::Feature::Factory#override_cast
|
271
|
-
|
271
|
+
|
272
272
|
def override_cast(original_, ntype_, flags_)
|
273
273
|
return nil unless Geos.supported?
|
274
274
|
keep_subtype_ = flags_[:keep_subtype]
|
@@ -302,11 +302,11 @@ module RGeo
|
|
302
302
|
end
|
303
303
|
false
|
304
304
|
end
|
305
|
-
|
306
|
-
|
305
|
+
|
306
|
+
|
307
307
|
end
|
308
|
-
|
309
|
-
|
308
|
+
|
309
|
+
|
310
310
|
end
|
311
|
-
|
311
|
+
|
312
312
|
end
|