Ticket #1673 (closed defect: fixed)

Opened 5 years ago

Last modified 5 years ago

OGR_G_CloseRings side-effect on OGR_G_GetGeometryType

Reported by: jbronn Owned by: mloskot
Priority: low Milestone: 1.4.2
Component: OGR_SF Version: 1.4.1
Severity: normal Keywords: geometry
Cc: jbronn@…, warmerdam

Description

After closing the rings on a Polygon, when attempting to get the geometry type of one of the closed rings, OGR returns a nonsense number. Exporting the closed-ring Polygon to WKT fixes this scenario, and the closed ring will subsequently return the correct geometry type.

Here is a Python script that demonstrates the problem:

import ogr

# Unclosed Polygon WKT
wkt = 'POLYGON((0 0, 5 0, 5 5, 0 5), (1 1, 2 1, 2 2, 2 1))'

if __name__=='__main__':

    # Creating the polygon from the WKT
    poly = ogr.CreateGeometryFromWkt(wkt)

    # Getting the exterior ring before we close all rings
    ring_b = poly.GetGeometryRef(0)
    print 'Ring Geometry Type Before Closure: %d' % ring_b.GetGeometryType()

    # Closing the rings
    poly.CloseRings()

    # Now getting the same ring again
    ring_a = poly.GetGeometryRef(0)
    print 'Ring Geometry Type After Closure: %d' % ring_a.GetGeometryType()

    # Exporting closed Polygon to  WKT "fixes" this.
    ring_wkt = str(poly)
    ring_a = poly.GetGeometryRef(0)
    print 'Ring Geometry Type Fixed: %d' % ring_a.GetGeometryType()

Here is the output from that script:

Ring Geometry Type Before Closure: 2
Ring Geometry Type After Closure: -2147483646
Ring Geometry Type Fixed: 2

Attachments

close_rings_test.cpp Download (2.0 KB) - added by mloskot 5 years ago.
C++ program reproducing this bug

Change History

Changed 5 years ago by jbronn

  • cc jbronn@… added

Changed 5 years ago by warmerdam

  • cc warmerdam added
  • keywords geometry added
  • component changed from default to OGR_SF
  • owner changed from warmerdam to mloskot
  • milestone set to 1.4.2

Mateusz,

Could you look into this?

Thanks,

Changed 5 years ago by mloskot

C++ program reproducing this bug

Changed 5 years ago by mloskot

  • status changed from new to assigned

Diagnosis:

  • In the closeRings() operation, if start point and end point differs, additional end point is added with the same coordinates of start point.
  • The addPoint() operation was passed with X,Y and Z coordinates without respect of current coordinate dimension.
  • Next, 2D ring was completed with end point of X,Y,Z coordinates what in turn caused re-qualification of coordinate dimension of the ring, from 2D to 2.5D.
  • In result, incorrect (different) geometry type of the ring was reported.

Solution:

The OGRLinearRing::closeRings() has to be patched to respect current coordinate dimension, to avoid implicit changes.

Changed 5 years ago by mloskot

  • status changed from assigned to closed
  • resolution set to fixed

Fixed in SVN trunk (r11694).

Changed 5 years ago by mloskot

Fix ported to branches/1.4 (r11695).

Note: See TracTickets for help on using tickets.