ffi-gdal 1.0.0.beta16 → 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (324) hide show
  1. checksums.yaml +4 -4
  2. data/.dockerignore +17 -0
  3. data/.github/workflows/codacy.yml +61 -0
  4. data/.github/workflows/codeql.yml +74 -0
  5. data/.github/workflows/continuous-integration.yml +36 -0
  6. data/.github/workflows/dependency-review.yml +20 -0
  7. data/.github/workflows/specs-in-docker.yml +27 -0
  8. data/.gitignore +3 -0
  9. data/.rspec +1 -0
  10. data/.rubocop.yml +10 -80
  11. data/.rubocop_todo.yml +23 -40
  12. data/.ruby-version +1 -1
  13. data/Changelog-0.x.md +512 -0
  14. data/Changelog.md +12 -0
  15. data/Dockerfile.gdal2 +110 -0
  16. data/Dockerfile.gdal3 +73 -0
  17. data/README.md +25 -14
  18. data/Rakefile +0 -8
  19. data/Tiltfile +91 -0
  20. data/bin/bundle +123 -0
  21. data/bin/docker-clean +8 -0
  22. data/bin/rake +29 -0
  23. data/bin/rspec +29 -0
  24. data/bin/rubocop +29 -0
  25. data/docker-compose.yml +25 -0
  26. data/examples/extract_and_colorize.rb +0 -13
  27. data/examples/geometries.rb +14 -14
  28. data/examples/ogr_layer_to_layer.rb +1 -3
  29. data/examples/raster_erasing.rb +1 -0
  30. data/examples/remove_small_polygons.rb +1 -1
  31. data/examples/testing_gdal.rb +20 -17
  32. data/examples/warping.rb +9 -7
  33. data/ffi-gdal.gemspec +12 -6
  34. data/lib/ext/ffi_library_function_checks.rb +2 -2
  35. data/lib/ext/to_bool.rb +5 -3
  36. data/lib/ffi/cpl/conv.rb +27 -25
  37. data/lib/ffi/cpl/error.rb +19 -20
  38. data/lib/ffi/cpl/hash_set.rb +4 -4
  39. data/lib/ffi/cpl/http.rb +3 -3
  40. data/lib/ffi/cpl/http_result.rb +8 -8
  41. data/lib/ffi/cpl/list.rb +1 -1
  42. data/lib/ffi/cpl/mime_part.rb +2 -2
  43. data/lib/ffi/cpl/minixml.rb +7 -7
  44. data/lib/ffi/cpl/progress.rb +8 -8
  45. data/lib/ffi/cpl/quad_tree.rb +14 -14
  46. data/lib/ffi/cpl/rect_obj.rb +3 -3
  47. data/lib/ffi/cpl/string.rb +17 -20
  48. data/lib/ffi/cpl/vsi.rb +13 -13
  49. data/lib/ffi/cpl/xml_node.rb +3 -3
  50. data/lib/ffi/extensions/gdal/extensions/all.rb +4 -0
  51. data/lib/ffi/extensions/gdal/extensions/version.rb +9 -0
  52. data/lib/ffi/extensions/gdal/extensions.rb +12 -0
  53. data/lib/ffi/extensions/rttopo/gbox.rb +19 -0
  54. data/lib/ffi/extensions/rttopo/geom.rb +16 -0
  55. data/lib/ffi/extensions/rttopo.rb +41 -0
  56. data/lib/ffi/gdal/alg.rb +277 -277
  57. data/lib/ffi/gdal/color_entry.rb +3 -3
  58. data/lib/ffi/gdal/gcp.rb +6 -6
  59. data/lib/ffi/gdal/gdal.rb +349 -349
  60. data/lib/ffi/gdal/grid.rb +134 -134
  61. data/lib/ffi/gdal/grid_data_metrics_options.rb +4 -4
  62. data/lib/ffi/gdal/grid_inverse_distance_to_a_power_options.rb +9 -9
  63. data/lib/ffi/gdal/grid_moving_average_options.rb +4 -4
  64. data/lib/ffi/gdal/grid_nearest_neighbor_options.rb +3 -3
  65. data/lib/ffi/gdal/matching.rb +3 -3
  66. data/lib/ffi/gdal/rpc_info.rb +17 -17
  67. data/lib/ffi/gdal/transformer_info.rb +4 -4
  68. data/lib/ffi/gdal/version.rb +1 -1
  69. data/lib/ffi/gdal/vrt.rb +39 -39
  70. data/lib/ffi/gdal/warp_options.rb +34 -34
  71. data/lib/ffi/gdal/warper.rb +90 -90
  72. data/lib/ffi/gdal.rb +2 -31
  73. data/lib/ffi/ogr/api.rb +175 -167
  74. data/lib/ffi/ogr/contour_writer_info.rb +4 -4
  75. data/lib/ffi/ogr/core.rb +107 -107
  76. data/lib/ffi/ogr/envelope.rb +3 -3
  77. data/lib/ffi/ogr/envelope_3d.rb +5 -5
  78. data/lib/ffi/ogr/featurestyle.rb +3 -3
  79. data/lib/ffi/ogr/field.rb +22 -22
  80. data/lib/ffi/ogr/geocoding.rb +4 -4
  81. data/lib/ffi/ogr/srs_api.rb +154 -155
  82. data/lib/ffi/ogr/style_param.rb +3 -3
  83. data/lib/ffi/ogr/style_value.rb +4 -4
  84. data/lib/gdal/color_entry.rb +1 -5
  85. data/lib/gdal/color_interpretation.rb +7 -3
  86. data/lib/gdal/color_table.rb +46 -27
  87. data/lib/gdal/cpl_error_handler.rb +26 -6
  88. data/lib/gdal/data_type.rb +10 -3
  89. data/lib/gdal/dataset.rb +171 -85
  90. data/lib/gdal/dataset_mixins/algorithm_methods.rb +44 -44
  91. data/lib/gdal/dataset_mixins/matching.rb +1 -1
  92. data/lib/gdal/dataset_mixins/warp_methods.rb +4 -2
  93. data/lib/gdal/driver.rb +38 -21
  94. data/lib/gdal/environment_methods.rb +6 -6
  95. data/lib/gdal/extensions/all.rb +3 -0
  96. data/lib/gdal/{color_entry_mixins → extensions/color_entry}/extensions.rb +4 -1
  97. data/lib/gdal/{color_table_mixins → extensions/color_table}/extensions.rb +3 -0
  98. data/lib/gdal/extensions/dataset/extensions.rb +205 -0
  99. data/lib/gdal/{driver_mixins → extensions/driver}/extensions.rb +6 -2
  100. data/lib/gdal/{geo_transform_mixins → extensions/geo_transform}/extensions.rb +10 -8
  101. data/lib/gdal/{gridder → extensions/gridder}/point_extracting.rb +7 -5
  102. data/lib/gdal/{gridder.rb → extensions/gridder.rb} +33 -33
  103. data/lib/gdal/{gridder_options.rb → extensions/gridder_options.rb} +13 -14
  104. data/lib/gdal/{raster_attribute_table_mixins → extensions/raster_attribute_table}/extensions.rb +8 -6
  105. data/lib/gdal/{raster_band_mixins → extensions/raster_band}/algorithm_extensions.rb +8 -6
  106. data/lib/gdal/{raster_band_mixins → extensions/raster_band}/coloring_extensions.rb +6 -4
  107. data/lib/gdal/{raster_band_mixins → extensions/raster_band}/extensions.rb +9 -5
  108. data/lib/gdal/{raster_band_mixins → extensions/raster_band}/io_extensions.rb +18 -14
  109. data/lib/gdal/{raster_band_classifier.rb → extensions/raster_band_classifier.rb} +3 -5
  110. data/lib/gdal/geo_transform.rb +1 -6
  111. data/lib/gdal/grid.rb +3 -2
  112. data/lib/gdal/grid_algorithms.rb +9 -9
  113. data/lib/gdal/internal_helpers.rb +46 -9
  114. data/lib/gdal/major_object.rb +11 -3
  115. data/lib/gdal/options.rb +26 -32
  116. data/lib/gdal/raster_attribute_table.rb +63 -37
  117. data/lib/gdal/raster_band.rb +164 -116
  118. data/lib/gdal/raster_band_mixins/algorithm_methods.rb +26 -25
  119. data/lib/gdal/rpc_info.rb +3 -2
  120. data/lib/gdal/transformers/approximate_transformer.rb +12 -3
  121. data/lib/gdal/transformers/base_general_image_projection_transformer.rb +15 -2
  122. data/lib/gdal/transformers/gcp_transformer.rb +27 -19
  123. data/lib/gdal/transformers/general_image_projection_transformer.rb +8 -6
  124. data/lib/gdal/transformers/general_image_projection_transformer2.rb +9 -6
  125. data/lib/gdal/transformers/general_image_projection_transformer3.rb +6 -2
  126. data/lib/gdal/transformers/geolocation_transformer.rb +12 -4
  127. data/lib/gdal/transformers/reprojection_transformer.rb +11 -3
  128. data/lib/gdal/transformers/rpc_transformer.rb +11 -2
  129. data/lib/gdal/transformers/tps_transformer.rb +12 -4
  130. data/lib/gdal/version_info.rb +2 -2
  131. data/lib/gdal/virtual_dataset.rb +2 -0
  132. data/lib/gdal/warp_operation.rb +65 -54
  133. data/lib/gdal/warp_options.rb +9 -11
  134. data/lib/ogr/coordinate_transformation.rb +23 -9
  135. data/lib/ogr/data_source.rb +68 -37
  136. data/lib/ogr/driver.rb +18 -17
  137. data/lib/ogr/envelope.rb +0 -3
  138. data/lib/ogr/error_handling.rb +22 -24
  139. data/lib/ogr/extensions/all.rb +3 -0
  140. data/lib/ogr/{data_source_mixins → extensions/data_source}/capability_methods.rb +2 -0
  141. data/lib/ogr/extensions/data_source/data_source_extensions.rb +16 -0
  142. data/lib/ogr/{driver_mixins → extensions/driver}/capability_methods.rb +5 -1
  143. data/lib/ogr/extensions/envelope/extensions.rb +114 -0
  144. data/lib/ogr/extensions/feature/extensions.rb +87 -0
  145. data/lib/ogr/extensions/feature_definition/extensions.rb +43 -0
  146. data/lib/ogr/extensions/geometries/point/extensions.rb +19 -0
  147. data/lib/ogr/extensions/geometry/container_mixins.rb +56 -0
  148. data/lib/ogr/extensions/geometry/ewkb_io_extensions.rb +44 -0
  149. data/lib/ogr/extensions/geometry/ewkb_record.rb +94 -0
  150. data/lib/ogr/{geometry_mixins → extensions/geometry}/extensions.rb +16 -9
  151. data/lib/ogr/extensions/geometry/rttopo_extensions.rb +48 -0
  152. data/lib/ogr/extensions/geometry/wkb_record.rb +63 -0
  153. data/lib/ogr/extensions/geometry_types/curve/extensions.rb +68 -0
  154. data/lib/ogr/{layer_mixins → extensions/layer}/capability_methods.rb +4 -0
  155. data/lib/ogr/{layer_mixins → extensions/layer}/extensions.rb +11 -6
  156. data/lib/ogr/extensions/spatial_reference/extensions.rb +38 -0
  157. data/lib/ogr/extensions/spatial_reference/initializers.rb +138 -0
  158. data/lib/ogr/extensions/style_table/extensions.rb +31 -0
  159. data/lib/ogr/feature.rb +173 -88
  160. data/lib/ogr/feature_definition.rb +53 -45
  161. data/lib/ogr/field.rb +17 -19
  162. data/lib/ogr/field_definition.rb +30 -18
  163. data/lib/ogr/geocoder.rb +11 -4
  164. data/lib/ogr/geometries/line_string.rb +1 -0
  165. data/lib/ogr/geometries/line_string_25d.rb +0 -9
  166. data/lib/ogr/geometries/linear_ring.rb +2 -2
  167. data/lib/ogr/geometries/point.rb +0 -9
  168. data/lib/ogr/geometry.rb +116 -49
  169. data/lib/ogr/geometry_field_definition.rb +31 -15
  170. data/lib/ogr/geometry_types/container.rb +26 -28
  171. data/lib/ogr/geometry_types/curve.rb +5 -61
  172. data/lib/ogr/geometry_types/surface.rb +1 -1
  173. data/lib/ogr/internal_helpers.rb +2 -2
  174. data/lib/ogr/layer.rb +12 -10
  175. data/lib/ogr/layer_mixins/ogr_feature_methods.rb +39 -27
  176. data/lib/ogr/layer_mixins/ogr_field_methods.rb +66 -50
  177. data/lib/ogr/layer_mixins/ogr_layer_method_methods.rb +17 -8
  178. data/lib/ogr/layer_mixins/ogr_query_filter_methods.rb +7 -6
  179. data/lib/ogr/layer_mixins/ogr_sql_methods.rb +15 -7
  180. data/lib/ogr/spatial_reference.rb +79 -42
  181. data/lib/ogr/spatial_reference_mixins/coordinate_system_getter_setters.rb +149 -118
  182. data/lib/ogr/spatial_reference_mixins/exporters.rb +87 -51
  183. data/lib/ogr/spatial_reference_mixins/importers.rb +88 -43
  184. data/lib/ogr/spatial_reference_mixins/morphers.rb +12 -8
  185. data/lib/ogr/spatial_reference_mixins/parameter_getter_setters.rb +27 -13
  186. data/lib/ogr/style_table.rb +15 -5
  187. data/lib/ogr/style_tool.rb +29 -15
  188. data/lib/ogr.rb +1 -0
  189. data/rakelib/docker.rake +10 -0
  190. data/sorbet/rbi/hidden-definitions/errors.txt +21790 -0
  191. data/tilt/gdal2.yml +22 -0
  192. data/tilt/gdal3.yml +22 -0
  193. metadata +116 -280
  194. data/History.md +0 -360
  195. data/lib/ext/error_symbols.rb +0 -7
  196. data/lib/gdal/dataset_mixins/extensions.rb +0 -380
  197. data/lib/gdal/merger.rb +0 -132
  198. data/lib/ogr/data_source_extensions.rb +0 -10
  199. data/lib/ogr/envelope_extensions.rb +0 -110
  200. data/lib/ogr/feature_definition_extensions.rb +0 -39
  201. data/lib/ogr/feature_extensions.rb +0 -87
  202. data/lib/ogr/geometry_mixins/container_mixins.rb +0 -25
  203. data/lib/ogr/spatial_reference_extensions.rb +0 -34
  204. data/lib/ogr/style_table_extensions.rb +0 -26
  205. data/spec/ffi-gdal_spec.rb +0 -24
  206. data/spec/integration/gdal/color_table_info_spec.rb +0 -78
  207. data/spec/integration/gdal/dataset_info_spec.rb +0 -342
  208. data/spec/integration/gdal/driver_info_spec.rb +0 -170
  209. data/spec/integration/gdal/geo_transform_info_spec.rb +0 -226
  210. data/spec/integration/gdal/gridder_spec.rb +0 -331
  211. data/spec/integration/gdal/raster_attribute_table_info_spec.rb +0 -229
  212. data/spec/integration/gdal/raster_band_algorithms_spec.rb +0 -35
  213. data/spec/integration/gdal/raster_band_info_spec.rb +0 -320
  214. data/spec/integration/ogr/layer_spec.rb +0 -95
  215. data/spec/spec_helper.rb +0 -116
  216. data/spec/support/images/123.tiff +0 -0
  217. data/spec/support/images/osgeo/gdal/data/hfa/float-rle.img +0 -0
  218. data/spec/support/images/osgeo/geotiff/GeogToWGS84GeoKey/GeogToWGS84GeoKey5.lgo +0 -31
  219. data/spec/support/images/osgeo/geotiff/GeogToWGS84GeoKey/GeogToWGS84GeoKey5.tif +0 -0
  220. data/spec/support/images/osgeo/geotiff/GeogToWGS84GeoKey/GeogToWGS84GeoKey5.tif.msk +0 -0
  221. data/spec/support/images/osgeo/geotiff/GeogToWGS84GeoKey/GeogToWGS84GeoKey5.txt +0 -10
  222. data/spec/support/images/osgeo/geotiff/gdal_eg/cea.tif +0 -0
  223. data/spec/support/images/osgeo/geotiff/gdal_eg/cea.txt +0 -84
  224. data/spec/support/images/osgeo/geotiff/zi_imaging/image0.lgo +0 -45
  225. data/spec/support/images/osgeo/geotiff/zi_imaging/image0.tif +0 -0
  226. data/spec/support/integration_help.rb +0 -34
  227. data/spec/support/shapefiles/states_21basic/states.dbf +0 -0
  228. data/spec/support/shapefiles/states_21basic/states.prj +0 -1
  229. data/spec/support/shapefiles/states_21basic/states.sbn +0 -0
  230. data/spec/support/shapefiles/states_21basic/states.sbx +0 -0
  231. data/spec/support/shapefiles/states_21basic/states.shp +0 -0
  232. data/spec/support/shapefiles/states_21basic/states.shp.xml +0 -3
  233. data/spec/support/shapefiles/states_21basic/states.shx +0 -0
  234. data/spec/support/shared_contexts.rb +0 -28
  235. data/spec/support/shared_examples/gdal/major_object_examples.rb +0 -55
  236. data/spec/support/shared_examples/ogr/a_25d_geometry.rb +0 -9
  237. data/spec/support/shared_examples/ogr/a_container_geometry.rb +0 -49
  238. data/spec/support/shared_examples/ogr/a_geometry.rb +0 -406
  239. data/spec/support/shared_examples/ogr/a_line_string.rb +0 -18
  240. data/spec/support/test_style_table.txt +0 -3
  241. data/spec/support/worldfiles/SR_50M/SR_50M.VERSION.txt +0 -1
  242. data/spec/support/worldfiles/SR_50M/SR_50M.prj +0 -1
  243. data/spec/support/worldfiles/SR_50M/SR_50M.tfw +0 -6
  244. data/spec/support/worldfiles/SR_50M/SR_50M.tif +0 -0
  245. data/spec/unit/ext/error_symbols_spec.rb +0 -69
  246. data/spec/unit/ext/numeric_as_data_type_spec.rb +0 -115
  247. data/spec/unit/ffi/gdal_spec.rb +0 -73
  248. data/spec/unit/gdal/color_entry_spec.rb +0 -8
  249. data/spec/unit/gdal/color_interpretation_spec.rb +0 -8
  250. data/spec/unit/gdal/color_table_mixins/extensions_spec.rb +0 -62
  251. data/spec/unit/gdal/color_table_spec.rb +0 -146
  252. data/spec/unit/gdal/data_type_spec.rb +0 -74
  253. data/spec/unit/gdal/dataset_mixins/warp_methods_spec.rb +0 -55
  254. data/spec/unit/gdal/dataset_spec.rb +0 -148
  255. data/spec/unit/gdal/driver_mixins/extensions_spec.rb +0 -24
  256. data/spec/unit/gdal/driver_spec.rb +0 -51
  257. data/spec/unit/gdal/environment_methods_spec.rb +0 -8
  258. data/spec/unit/gdal/geo_transform_mixins/extensions_spec.rb +0 -69
  259. data/spec/unit/gdal/geo_transform_spec.rb +0 -265
  260. data/spec/unit/gdal/grid_spec.rb +0 -98
  261. data/spec/unit/gdal/gridder/point_extracting_spec.rb +0 -101
  262. data/spec/unit/gdal/gridder_options_spec.rb +0 -185
  263. data/spec/unit/gdal/gridder_spec.rb +0 -182
  264. data/spec/unit/gdal/internal_helpers_spec.rb +0 -278
  265. data/spec/unit/gdal/major_object_spec.rb +0 -10
  266. data/spec/unit/gdal/options_spec.rb +0 -33
  267. data/spec/unit/gdal/raster_attribute_table_spec.rb +0 -7
  268. data/spec/unit/gdal/raster_band_classifier_spec.rb +0 -260
  269. data/spec/unit/gdal/raster_band_mixins/extensions_spec.rb +0 -73
  270. data/spec/unit/gdal/raster_band_mixins/io_extensions_spec.rb +0 -135
  271. data/spec/unit/gdal/raster_band_spec.rb +0 -8
  272. data/spec/unit/gdal/rpc_info_spec.rb +0 -8
  273. data/spec/unit/gdal/version_info_spec.rb +0 -10
  274. data/spec/unit/gdal/virtual_dataset_spec.rb +0 -34
  275. data/spec/unit/gdal/warp_operation_spec.rb +0 -8
  276. data/spec/unit/gdal/warp_options_spec.rb +0 -338
  277. data/spec/unit/ogr/coordinate_transformation_spec.rb +0 -104
  278. data/spec/unit/ogr/data_source_mixins/capability_methods_spec.rb +0 -32
  279. data/spec/unit/ogr/data_source_spec.rb +0 -223
  280. data/spec/unit/ogr/driver_mixins/capability_methods_spec.rb +0 -20
  281. data/spec/unit/ogr/driver_spec.rb +0 -152
  282. data/spec/unit/ogr/envelope_spec.rb +0 -324
  283. data/spec/unit/ogr/feature_definition_spec.rb +0 -296
  284. data/spec/unit/ogr/feature_extensions_spec.rb +0 -90
  285. data/spec/unit/ogr/feature_spec.rb +0 -363
  286. data/spec/unit/ogr/field_definition_spec.rb +0 -118
  287. data/spec/unit/ogr/field_spec.rb +0 -195
  288. data/spec/unit/ogr/geometries/geometry_collection_25d_spec.rb +0 -25
  289. data/spec/unit/ogr/geometries/geometry_collection_spec.rb +0 -188
  290. data/spec/unit/ogr/geometries/line_string_25d_spec.rb +0 -25
  291. data/spec/unit/ogr/geometries/line_string_spec.rb +0 -107
  292. data/spec/unit/ogr/geometries/linear_ring_spec.rb +0 -92
  293. data/spec/unit/ogr/geometries/multi_line_string_25d_spec.rb +0 -25
  294. data/spec/unit/ogr/geometries/multi_line_string_spec.rb +0 -16
  295. data/spec/unit/ogr/geometries/multi_point_25d_spec.rb +0 -25
  296. data/spec/unit/ogr/geometries/multi_point_spec.rb +0 -16
  297. data/spec/unit/ogr/geometries/multi_polygon_25d_spec.rb +0 -25
  298. data/spec/unit/ogr/geometries/multi_polygon_spec.rb +0 -43
  299. data/spec/unit/ogr/geometries/none_geometry_spec.rb +0 -14
  300. data/spec/unit/ogr/geometries/point_25d_spec.rb +0 -25
  301. data/spec/unit/ogr/geometries/point_spec.rb +0 -307
  302. data/spec/unit/ogr/geometries/polygon_25d_spec.rb +0 -25
  303. data/spec/unit/ogr/geometries/polygon_spec.rb +0 -19
  304. data/spec/unit/ogr/geometries/unknown_geometry_spec.rb +0 -12
  305. data/spec/unit/ogr/geometry_field_definition_spec.rb +0 -73
  306. data/spec/unit/ogr/geometry_spec.rb +0 -711
  307. data/spec/unit/ogr/internal_helpers_spec.rb +0 -70
  308. data/spec/unit/ogr/layer_mixins/capability_methods_spec.rb +0 -90
  309. data/spec/unit/ogr/layer_mixins/ogr_feature_methods_spec.rb +0 -155
  310. data/spec/unit/ogr/layer_mixins/ogr_field_methods_spec.rb +0 -434
  311. data/spec/unit/ogr/layer_mixins/ogr_layer_method_methods_spec.rb +0 -22
  312. data/spec/unit/ogr/layer_mixins/ogr_query_filter_methods_spec.rb +0 -44
  313. data/spec/unit/ogr/layer_mixins/ogr_sql_methods_spec.rb +0 -14
  314. data/spec/unit/ogr/layer_spec.rb +0 -98
  315. data/spec/unit/ogr/spatial_reference_mixins/coordinate_system_getter_setters_spec.rb +0 -48
  316. data/spec/unit/ogr/spatial_reference_mixins/exporters_spec.rb +0 -151
  317. data/spec/unit/ogr/spatial_reference_mixins/importers_spec.rb +0 -40
  318. data/spec/unit/ogr/spatial_reference_mixins/morphers_spec.rb +0 -38
  319. data/spec/unit/ogr/spatial_reference_mixins/parameter_getter_setters_spec.rb +0 -105
  320. data/spec/unit/ogr/spatial_reference_mixins/type_checks_spec.rb +0 -159
  321. data/spec/unit/ogr/spatial_reference_spec.rb +0 -44
  322. data/spec/unit/ogr/style_table_spec.rb +0 -108
  323. data/spec/unit/ogr/style_tool_spec.rb +0 -159
  324. data/spec/unit/version_info_spec.rb +0 -50
@@ -1,711 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require 'spec_helper'
4
- require 'ogr/geometry'
5
-
6
- RSpec.describe OGR::Geometry do
7
- describe '.create_from_wkt' do
8
- subject { OGR::Geometry.create_from_wkt(wkt) }
9
-
10
- context 'a 2D Point' do
11
- let(:wkt) { 'POINT(1 32)' }
12
- it { is_expected.to be_a OGR::Point }
13
- end
14
-
15
- context 'a 2.5D Point' do
16
- let(:wkt) { 'POINT(1 32 100)' }
17
- it { is_expected.to be_a OGR::Point25D }
18
- end
19
-
20
- context 'a 2D LineString' do
21
- let(:wkt) { 'LINESTRING(3 19,12 20)' }
22
- it { is_expected.to be_a OGR::LineString }
23
- end
24
-
25
- context 'a 2.5D LineString' do
26
- let(:wkt) { 'LINESTRING(3 4 19,12 23 20)' }
27
- it { is_expected.to be_a OGR::LineString25D }
28
- end
29
-
30
- context 'a 2D Polygon' do
31
- let(:wkt) { 'POLYGON((1 1,2 2,3 3))' }
32
- it { is_expected.to be_a OGR::Polygon }
33
- end
34
-
35
- context 'a 2.5D Polygon' do
36
- let(:wkt) { 'POLYGON((1 1 1,2 2 2,3 3 3))' }
37
- it { is_expected.to be_a OGR::Polygon25D }
38
- end
39
-
40
- context 'a 2D MultiPoint' do
41
- let(:wkt) { 'MULTIPOINT((1 1),(2 2))' }
42
- it { is_expected.to be_a OGR::MultiPoint }
43
- end
44
-
45
- context 'a 2.5D MultiPoint' do
46
- let(:wkt) { 'MULTIPOINT((1 1 1),(2 2 2))' }
47
- it { is_expected.to be_a OGR::MultiPoint25D }
48
- end
49
-
50
- context 'a 2D MultiLineString' do
51
- let(:wkt) { 'MULTILINESTRING((3 4),(100 20))' }
52
- it { is_expected.to be_a OGR::MultiLineString }
53
- end
54
-
55
- context 'a 2.5D MultiLineString' do
56
- let(:wkt) { 'MULTILINESTRING((3 4 19),(100 20 40))' }
57
- it { is_expected.to be_a OGR::MultiLineString25D }
58
- end
59
-
60
- context 'a 2D MultiPolygon' do
61
- let(:wkt) do
62
- 'MULTIPOLYGON(((1 1,2 2,3 3)),((100 100, 20 20, 30 30)))'
63
- end
64
-
65
- it { is_expected.to be_a OGR::MultiPolygon }
66
- end
67
-
68
- context 'a 2.5D MultiPolygon' do
69
- let(:wkt) do
70
- 'MULTIPOLYGON(((1 1 1,2 2 2,3 3 3)),((100 100 100, 20 20 20, 30 30 30)))'
71
- end
72
-
73
- it { is_expected.to be_a OGR::MultiPolygon25D }
74
- end
75
- end
76
-
77
- describe '.create_from_json' do
78
- subject { OGR::Geometry.create_from_json(json) }
79
-
80
- context 'a 2D Point' do
81
- let(:json) do
82
- { type: :Point, coordinates: [1.0, 7.0] }.to_json
83
- end
84
-
85
- it { is_expected.to be_a OGR::Point }
86
- end
87
-
88
- context 'a 2.5D Point' do
89
- let(:json) do
90
- { type: :Point, coordinates: [1.0, 2.0, 3.0] }.to_json
91
- end
92
-
93
- it { is_expected.to be_a OGR::Point25D }
94
- end
95
-
96
- context 'a 2D LineString' do
97
- let(:json) do
98
- {
99
- type: :LineString,
100
- coordinates: [
101
- [3.0, 4.0], [20.0, 30.0]
102
- ]
103
- }.to_json
104
- end
105
-
106
- it { is_expected.to be_a OGR::LineString }
107
- end
108
-
109
- context 'a 2.5D LineString' do
110
- let(:json) do
111
- {
112
- type: :LineString,
113
- coordinates: [
114
- [3.0, 4.0, 19.0], [20.0, 30.0, 45.0]
115
- ]
116
- }.to_json
117
- end
118
-
119
- it { is_expected.to be_a OGR::LineString25D }
120
- end
121
-
122
- context 'a 2D Polygon' do
123
- let(:json) do
124
- {
125
- type: :Polygon,
126
- coordinates: [
127
- [
128
- [1.0, 1.0], [5.0, 1.0], [5.0, 5.0], [1.0, 5.0], [1.0, 1.0]
129
- ]
130
- ]
131
- }.to_json
132
- end
133
-
134
- it { is_expected.to be_a OGR::Polygon }
135
- end
136
-
137
- context 'a 2.5D Polygon' do
138
- let(:json) do
139
- {
140
- type: :Polygon,
141
- coordinates: [
142
- [
143
- [1.0, 1.0, 1.0], [5.0, 1.0, 1.0], [5.0, 5.0, 1.0], [1.0, 5.0, 1.0], [1.0, 1.0]
144
- ]
145
- ]
146
- }.to_json
147
- end
148
-
149
- it { is_expected.to be_a OGR::Polygon25D }
150
- end
151
-
152
- context 'a 2D MultiPoint' do
153
- let(:json) do
154
- {
155
- type: :MultiPoint,
156
- coordinates: [
157
- [1.0, 1.0], [2.0, 2.0], [2.0, 1.0], [1.0, 1.0]
158
- ]
159
- }.to_json
160
- end
161
-
162
- it { is_expected.to be_a OGR::MultiPoint }
163
- end
164
-
165
- context 'a 2.5D MultiPoint' do
166
- let(:json) do
167
- {
168
- type: :MultiPoint,
169
- coordinates: [
170
- [1.0, 1.0, 1.0], [2.0, 2.0, 2.0], [2.0, 1.0, 2.0], [1.0, 1.0, 1.0]
171
- ]
172
- }.to_json
173
- end
174
-
175
- it { is_expected.to be_a OGR::MultiPoint25D }
176
- end
177
-
178
- context 'a 2D MultiLineString' do
179
- let(:json) do
180
- {
181
- type: :MultiLineString,
182
- coordinates: [
183
- [
184
- [3.0, 4.0], [21.0, 27.0], [2.0, 5.0]
185
- ], [
186
- [100.0, 20.0], [982.0, 6.0]
187
- ]
188
- ]
189
- }.to_json
190
- end
191
-
192
- it { is_expected.to be_a OGR::MultiLineString }
193
- end
194
-
195
- context 'a 2.5D MultiLineString' do
196
- let(:json) do
197
- {
198
- type: :MultiLineString,
199
- coordinates: [
200
- [
201
- [3.0, 4.0, 19.0], [21.0, 27.0, 30.0]
202
- ], [
203
- [100.0, 20.0, 400.0], [92.0, 6.0, 47.1]
204
- ]
205
- ]
206
- }.to_json
207
- end
208
-
209
- it { is_expected.to be_a OGR::MultiLineString25D }
210
- end
211
-
212
- context 'a 2D MultiPolygon' do
213
- let(:json) do
214
- {
215
- type: :MultiPolygon,
216
- coordinates: [
217
- [
218
- [
219
- [1.0, 1.0], [2.0, 2.0], [3.0, 3.0]
220
- ], [
221
- [11.0, 11.0], [10.0, 10.0], [9.0, 9.0]
222
- ]
223
- ], [
224
- [
225
- [100.0, 100.0], [20.0, 20.0], [30.0, 30.0]
226
- ], [
227
- [10.0, 10.0], [20.0, 20.0], [30.0, 30.0]
228
- ]
229
- ]
230
- ]
231
- }.to_json
232
- end
233
-
234
- it { is_expected.to be_a OGR::MultiPolygon }
235
- end
236
-
237
- context 'a 2.5D MultiPolygon' do
238
- let(:json) do
239
- {
240
- type: :MultiPolygon,
241
- coordinates: [
242
- [
243
- [
244
- [1.0, 1.0, 1.0], [2.0, 2.0, 2.0], [3.0, 3.0, 3.0]
245
- ], [
246
- [11.0, 11.0, 11.0], [10.0, 10.0, 10.0], [9.0, 9.0, 9.0]
247
- ]
248
- ], [
249
- [
250
- [100.0, 100.0, 100.0], [20.0, 20.0, 20.0], [30.0, 30.0, 30.0]
251
- ], [
252
- [10.0, 10.0, 10.0], [20.0, 20.0, 20.0], [30.0, 30.0, 30.0]
253
- ]
254
- ]
255
- ]
256
- }.to_json
257
- end
258
-
259
- it { is_expected.to be_a OGR::MultiPolygon25D }
260
- end
261
- end
262
-
263
- describe '.create_from_gml' do
264
- subject { OGR::Geometry.create_from_gml(gml) }
265
-
266
- context 'a 2D Point' do
267
- let(:gml) do
268
- '<gml:Point><gml:coordinates>1,7</gml:coordinates></gml:Point>'
269
- end
270
-
271
- it { is_expected.to be_a OGR::Point }
272
- end
273
-
274
- context 'a 2.5D Point' do
275
- let(:gml) do
276
- '<gml:Point><gml:coordinates>1,7,25</gml:coordinates></gml:Point>'
277
- end
278
-
279
- it { is_expected.to be_a OGR::Point25D }
280
- end
281
-
282
- context 'a 2D LineString' do
283
- let(:gml) do
284
- '<gml:LineString><gml:coordinates>3,4</gml:coordinates></gml:LineString>'
285
- end
286
-
287
- it { is_expected.to be_a OGR::LineString }
288
- end
289
-
290
- context 'a 2.5D LineString' do
291
- let(:gml) do
292
- '<gml:LineString><gml:coordinates>3,4,19</gml:coordinates></gml:LineString>'
293
- end
294
-
295
- it { is_expected.to be_a OGR::LineString25D }
296
- end
297
-
298
- context 'a 2D Polygon' do
299
- let(:gml) do
300
- <<-GML
301
- <gml:Polygon>
302
- <gml:outerBoundaryIs>
303
- <gml:LinearRing>
304
- <gml:coordinates>1,1 5,1 5,5 1,5 1,1</gml:coordinates>
305
- </gml:LinearRing>
306
- </gml:outerBoundaryIs>
307
- </gml:Polygon>
308
- GML
309
- end
310
-
311
- it { is_expected.to be_a OGR::Polygon }
312
- end
313
-
314
- context 'a 2.5D Polygon' do
315
- let(:gml) do
316
- <<-GML
317
- <gml:Polygon>
318
- <gml:outerBoundaryIs>
319
- <gml:LinearRing>
320
- <gml:coordinates>1,1,3 5,1,3 5,5,3 1,5,3 1,1,3</gml:coordinates>
321
- </gml:LinearRing>
322
- </gml:outerBoundaryIs>
323
- </gml:Polygon>
324
- GML
325
- end
326
-
327
- it { is_expected.to be_a OGR::Polygon25D }
328
- end
329
-
330
- context 'a 2D MultiPoint' do
331
- let(:gml) do
332
- <<-GML
333
- <gml:MultiPoint>
334
- <gml:pointMember>
335
- <gml:Point>
336
- <gml:coordinates>1,1</gml:coordinates>
337
- </gml:Point>
338
- </gml:pointMember>
339
- <gml:pointMember>
340
- <gml:Point>
341
- <gml:coordinates>2,2</gml:coordinates>
342
- </gml:Point>
343
- </gml:pointMember>
344
- <gml:pointMember>
345
- <gml:Point>
346
- <gml:coordinates>2,1</gml:coordinates>
347
- </gml:Point>
348
- </gml:pointMember>
349
- <gml:pointMember>
350
- <gml:Point>
351
- <gml:coordinates>1,1</gml:coordinates>
352
- </gml:Point>
353
- </gml:pointMember>
354
- </gml:MultiPoint>
355
- GML
356
- end
357
-
358
- it { is_expected.to be_a OGR::MultiPoint }
359
- end
360
-
361
- context 'a 2.5D MultiPoint' do
362
- let(:gml) do
363
- <<-GML
364
- <gml:MultiPoint>
365
- <gml:pointMember>
366
- <gml:Point>
367
- <gml:coordinates>1,1,3</gml:coordinates>
368
- </gml:Point>
369
- </gml:pointMember>
370
- <gml:pointMember>
371
- <gml:Point>
372
- <gml:coordinates>2,2,3</gml:coordinates>
373
- </gml:Point>
374
- </gml:pointMember>
375
- <gml:pointMember>
376
- <gml:Point>
377
- <gml:coordinates>2,1,3</gml:coordinates>
378
- </gml:Point>
379
- </gml:pointMember>
380
- <gml:pointMember>
381
- <gml:Point>
382
- <gml:coordinates>1,1,3</gml:coordinates>
383
- </gml:Point>
384
- </gml:pointMember>
385
- </gml:MultiPoint>
386
- GML
387
- end
388
-
389
- it { is_expected.to be_a OGR::MultiPoint25D }
390
- end
391
-
392
- context 'a 2D MultiLineString' do
393
- let(:gml) do
394
- <<-GML
395
- <gml:MultiLineString>
396
- <gml:lineStringMember>
397
- <gml:LineString>
398
- <gml:coordinates>3,4</gml:coordinates>
399
- </gml:LineString>
400
- </gml:lineStringMember>
401
- <gml:lineStringMember>
402
- <gml:LineString>
403
- <gml:coordinates>100,20</gml:coordinates>
404
- </gml:LineString>
405
- </gml:lineStringMember>
406
- </gml:MultiLineString>
407
- GML
408
- end
409
-
410
- it { is_expected.to be_a OGR::MultiLineString }
411
- end
412
-
413
- context 'a 2.5D MultiLineString' do
414
- let(:gml) do
415
- <<-GML
416
- <gml:MultiLineString>
417
- <gml:lineStringMember>
418
- <gml:LineString>
419
- <gml:coordinates>3,4,19</gml:coordinates>
420
- </gml:LineString>
421
- </gml:lineStringMember>
422
- <gml:lineStringMember>
423
- <gml:LineString>
424
- <gml:coordinates>100,20,40</gml:coordinates>
425
- </gml:LineString>
426
- </gml:lineStringMember>
427
- </gml:MultiLineString>
428
- GML
429
- end
430
-
431
- it { is_expected.to be_a OGR::MultiLineString25D }
432
- end
433
-
434
- context 'a 2D MultiPolygon' do
435
- let(:gml) do
436
- <<-GML
437
- <gml:MultiPolygon>
438
- <gml:polygonMember>
439
- <gml:Polygon>
440
- <gml:outerBoundaryIs>
441
- <gml:LinearRing>
442
- <gml:coordinates>1,1 2,2 3,3</gml:coordinates>
443
- </gml:LinearRing>
444
- </gml:outerBoundaryIs>
445
- </gml:Polygon>
446
- </gml:polygonMember>
447
- <gml:polygonMember>
448
- <gml:Polygon>
449
- <gml:outerBoundaryIs>
450
- <gml:LinearRing>
451
- <gml:coordinates>100,100 20,20 30,30</gml:coordinates>
452
- </gml:LinearRing>
453
- </gml:outerBoundaryIs>
454
- </gml:Polygon>
455
- </gml:polygonMember>
456
- </gml:MultiPolygon>
457
- GML
458
- end
459
-
460
- it { is_expected.to be_a OGR::MultiPolygon }
461
- end
462
-
463
- context 'a 2.5D MultiPolygon' do
464
- let(:gml) do
465
- <<-GML
466
- <gml:MultiPolygon>
467
- <gml:polygonMember>
468
- <gml:Polygon>
469
- <gml:outerBoundaryIs>
470
- <gml:LinearRing>
471
- <gml:coordinates>1,1,9 2,2,9 3,3,9</gml:coordinates>
472
- </gml:LinearRing>
473
- </gml:outerBoundaryIs>
474
- </gml:Polygon>
475
- </gml:polygonMember>
476
- <gml:polygonMember>
477
- <gml:Polygon>
478
- <gml:outerBoundaryIs>
479
- <gml:LinearRing>
480
- <gml:coordinates>100,100,9 20,20,9 30,30,9</gml:coordinates>
481
- </gml:LinearRing>
482
- </gml:outerBoundaryIs>
483
- </gml:Polygon>
484
- </gml:polygonMember>
485
- </gml:MultiPolygon>
486
- GML
487
- end
488
-
489
- it { is_expected.to be_a OGR::MultiPolygon25D }
490
- end
491
- end
492
-
493
- describe '.create_from_wkb' do
494
- subject { OGR::Geometry.create_from_wkb(wkb) }
495
-
496
- context 'a 2D Point' do
497
- # POINT(1 32)
498
- let(:wkb) { ['0101000000000000000000f03f0000000000004040'].pack('H*') }
499
- it { is_expected.to be_a OGR::Point }
500
- end
501
-
502
- context 'a 2.5D Point' do
503
- # POINT(1 32 100)
504
- let(:wkb) { ['01e9030000000000000000f03f00000000000040400000000000005940'].pack('H*') }
505
- it { is_expected.to be_a OGR::Point }
506
- end
507
-
508
- context 'a 2D LineString' do
509
- # LINESTRING(3 19,12 20)
510
- let(:wkb) do
511
- ['0102000000020000000000000000000840000000000000334000000000000028400000000000003440'].pack('H*')
512
- end
513
- it { is_expected.to be_a OGR::LineString }
514
- end
515
-
516
- context 'a 2.5D LineString' do
517
- # LINESTRING(3 4 19,12 13 20)
518
- let(:wkb) do
519
- hex = '01ea030000020000000000000000000840000000000000104000000000000' \
520
- '03340000000000000284000000000000037400000000000003440'
521
- [hex].pack('H*')
522
- end
523
-
524
- it { is_expected.to be_a OGR::LineString25D }
525
- end
526
-
527
- context 'a 2D Polygon' do
528
- # 'POLYGON((1 1,2 1,3 0,1 1))'
529
- let(:wkb) do
530
- hex = '01030000000100000004000000000000000000f03f000000000000f03f0000' \
531
- '000000000040000000000000f03f00000000000008400000000000000000000000' \
532
- '000000f03f000000000000f03f'
533
- [hex].pack('H*')
534
- end
535
-
536
- it { is_expected.to be_a OGR::Polygon }
537
- end
538
-
539
- context 'a 2.5D Polygon' do
540
- let(:wkb) do
541
- # 'POLYGON((1 1 1,2 1 1,2 0 1,1 1 1))'
542
- hex = '01eb0300000100000004000000000000000000f03f000000000000f03f0000' \
543
- '00000000f03f0000000000000040000000000000f03f000000000000f03f000000' \
544
- '00000000400000000000000000000000000000f03f000000000000f03f00000000' \
545
- '0000f03f000000000000f03f'
546
- [hex].pack('H*')
547
- end
548
- it { is_expected.to be_a OGR::Polygon25D }
549
- end
550
-
551
- context 'a 2D MultiPoint' do
552
- let(:wkb) do
553
- # 'MULTIPOINT((0 0),(1 1))'
554
- hex = '01040000000200000001010000000000000000000000000000000000000001' \
555
- '01000000000000000000f03f000000000000f03f'
556
- [hex].pack('H*')
557
- end
558
- it { is_expected.to be_a OGR::MultiPoint }
559
- end
560
-
561
- context 'a 2.5D MultiPoint' do
562
- let(:wkb) do
563
- # 'MULTIPOINT((0 0 0),(1 1 1))'
564
- hex = '01ec0300000200000001e90300000000000000000000000000000000000000' \
565
- '0000000000000001e9030000000000000000f03f000000000000f03f0000000000' \
566
- '00f03f'
567
- [hex].pack('H*')
568
- end
569
- it { is_expected.to be_a OGR::MultiPoint25D }
570
- end
571
-
572
- context 'a 2D MultiLineString' do
573
- let(:wkb) do
574
- # 'MULTILINESTRING((1 1,2 2, 3 3),(10 10,20 20,30 30))'
575
- hex = '010500000002000000010200000003000000000000000000f03f0000000000' \
576
- '00f03f000000000000004000000000000000400000000000000840000000000000' \
577
- '084001020000000300000000000000000024400000000000002440000000000000' \
578
- '344000000000000034400000000000003e400000000000003e40'
579
- [hex].pack('H*')
580
- end
581
- it { is_expected.to be_a OGR::MultiLineString }
582
- end
583
-
584
- context 'a 2.5D MultiLineString' do
585
- let(:wkb) do
586
- # MULTILINESTRING((3 4 19,100 20 40),(5 5 5,6 6 6,7 7 7))
587
- hex = '01ed0300000200000001ea0300000200000000000000000008400000000000' \
588
- '001040000000000000334000000000000059400000000000003440000000000000' \
589
- '444001ea0300000300000000000000000014400000000000001440000000000000' \
590
- '14400000000000001840000000000000184000000000000018400000000000001c' \
591
- '400000000000001c400000000000001c40'
592
- [hex].pack('H*')
593
- end
594
- it { is_expected.to be_a OGR::MultiLineString25D }
595
- end
596
-
597
- context 'a 2D MultiPolygon' do
598
- # 'MULTIPOLYGON(((1 1,2 1,2 0,1 1)),((100 100,20 20,30 30,100 100)))'
599
- let(:wkb) do
600
- hex = '01060000000200000001030000000100000004000000000000000000f03f00' \
601
- '0000000000f03f0000000000000040000000000000f03f00000000000000400000' \
602
- '000000000000000000000000f03f000000000000f03f0103000000010000000400' \
603
- '000000000000000059400000000000005940000000000000344000000000000034' \
604
- '400000000000003e400000000000003e4000000000000059400000000000005940'
605
- [hex].pack('H*')
606
- end
607
-
608
- it { is_expected.to be_a OGR::MultiPolygon }
609
- end
610
-
611
- context 'a 2.5D MultiPolygon' do
612
- # 'MULTIPOLYGON(((1 1 1,2 1 2,2 0 3,1 1 1)),((100 100 100,20 20 20,30 30 30,100 100 100)))'
613
- let(:wkb) do
614
- hex = '01ee0300000200000001eb0300000100000004000000000000000000f03f00' \
615
- '0000000000f03f000000000000f03f0000000000000040000000000000f03f0000' \
616
- '000000000040000000000000004000000000000000000000000000000840000000' \
617
- '000000f03f000000000000f03f000000000000f03f01eb03000001000000040000' \
618
- '000000000000005940000000000000594000000000000059400000000000003440' \
619
- '000000000000344000000000000034400000000000003e400000000000003e4000' \
620
- '00000000003e40000000000000594000000000000059400000000000005940'
621
- [hex].pack('H*')
622
- end
623
-
624
- it { is_expected.to be_a OGR::MultiPolygon25D }
625
- end
626
- end
627
-
628
- describe '.type_to_name' do
629
- context 'wkbUnknown' do
630
- subject { described_class.type_to_name(:wkbUnknown) }
631
- it { is_expected.to eq 'Unknown (any)' }
632
- end
633
-
634
- context 'wkbPoint' do
635
- subject { described_class.type_to_name(:wkbPoint) }
636
- it { is_expected.to eq 'Point' }
637
- end
638
-
639
- context 'wkbLineString' do
640
- subject { described_class.type_to_name(:wkbLineString) }
641
- it { is_expected.to eq 'Line String' }
642
- end
643
-
644
- context 'wkbPolygon' do
645
- subject { described_class.type_to_name(:wkbPolygon) }
646
- it { is_expected.to eq 'Polygon' }
647
- end
648
-
649
- context 'wkbMultiPoint' do
650
- subject { described_class.type_to_name(:wkbMultiPoint) }
651
- it { is_expected.to eq 'Multi Point' }
652
- end
653
-
654
- context 'wkbMultiLineString' do
655
- subject { described_class.type_to_name(:wkbMultiLineString) }
656
- it { is_expected.to eq 'Multi Line String' }
657
- end
658
-
659
- context 'wkbMultiPolygon' do
660
- subject { described_class.type_to_name(:wkbMultiPolygon) }
661
- it { is_expected.to eq 'Multi Polygon' }
662
- end
663
-
664
- context 'wkbGeometryCollection' do
665
- subject { described_class.type_to_name(:wkbGeometryCollection) }
666
- it { is_expected.to eq 'Geometry Collection' }
667
- end
668
-
669
- context 'wkbNone' do
670
- subject { described_class.type_to_name(:wkbNone) }
671
- it { is_expected.to eq 'None' }
672
- end
673
-
674
- context 'wkbLinearRing' do
675
- subject { described_class.type_to_name(:wkbLinearRing) }
676
- # Per GDAL docs, LinearRing is only used for geometry creation.
677
- it { is_expected.to eq 'Unrecognized: 101' }
678
- end
679
- end
680
-
681
- describe '#utm_zone' do
682
- let(:geom) { OGR::Geometry.create_from_wkt(wkt) }
683
-
684
- let(:wkt) do
685
- 'LINESTRING(100 100, 20 20, 30 30, 100 100)'
686
- end
687
-
688
- context 'no spatial_reference' do
689
- subject { geom.utm_zone }
690
- it { is_expected.to be_nil }
691
- end
692
-
693
- context 'SRID is 4326' do
694
- subject { geom.utm_zone }
695
- before { geom.spatial_reference = OGR::SpatialReference.new_from_epsg(4326) }
696
- it { is_expected.to eq(36) }
697
- end
698
-
699
- context 'SRID is not 4326' do
700
- before { geom.spatial_reference = OGR::SpatialReference.new_from_epsg(3857) }
701
-
702
- it 'transforms to 4326 then figures out the zone' do
703
- duped_subject = geom.dup
704
- expect(geom).to receive(:dup).and_return(duped_subject)
705
- expect(duped_subject).to receive(:transform_to!).and_call_original
706
-
707
- geom.utm_zone
708
- end
709
- end
710
- end
711
- end