[geos-commits] r3514 - in trunk: src/operation/union
	tests/unit/operation/union tests/xmltester/tests/general
    svn_geos at osgeo.org 
    svn_geos at osgeo.org
       
    Fri Nov  4 13:59:22 EDT 2011
    
    
  
Author: strk
Date: 2011-11-04 10:59:22 -0700 (Fri, 04 Nov 2011)
New Revision: 3514
Modified:
   trunk/src/operation/union/UnaryUnionOp.cpp
   trunk/tests/unit/operation/union/UnaryUnionOpTest.cpp
   trunk/tests/xmltester/tests/general/TestUnaryUnion.xml
Log:
Fix noding of self-intersecting lines through UnaryUnion (#482)
Includes updated tests from JTS
Modified: trunk/src/operation/union/UnaryUnionOp.cpp
===================================================================
--- trunk/src/operation/union/UnaryUnionOp.cpp	2011-11-04 17:45:43 UTC (rev 3513)
+++ trunk/src/operation/union/UnaryUnionOp.cpp	2011-11-04 17:59:22 UTC (rev 3514)
@@ -82,13 +82,18 @@
 
   GeomAutoPtr unionLines;
   if (!lines.empty()) {
-#if 0
-      GeomAutoPtr lineGeom = geomFact->buildGeometry( lines.begin(),
-                                                      lines.end()    );
-      unionLines = unionNoOpt(*lineGeom);
-#endif
+      /* JTS compatibility NOTE:
+       * we use cascaded here for robustness [1]
+       * but also add a final unionNoOpt step to deal with
+       * self-intersecting lines [2]
+       *
+       * [1](http://trac.osgeo.org/geos/ticket/392
+       * [2](http://trac.osgeo.org/geos/ticket/482
+       *
+       */
       unionLines.reset( CascadedUnion::Union( lines.begin(),
                                               lines.end()   ) );
+      unionLines = unionNoOpt(*unionLines);
   }
 
   GeomAutoPtr unionPolygons;
Modified: trunk/tests/unit/operation/union/UnaryUnionOpTest.cpp
===================================================================
--- trunk/tests/unit/operation/union/UnaryUnionOpTest.cpp	2011-11-04 17:45:43 UTC (rev 3513)
+++ trunk/tests/unit/operation/union/UnaryUnionOpTest.cpp	2011-11-04 17:59:22 UTC (rev 3514)
@@ -1,5 +1,5 @@
 // 
-// Test Suite for geos::operation::geounion::CascadedPolygonUnion class.
+// Test Suite for geos::operation::geounion::UnaryUnionOp class.
 
 // tut
 #include <tut.hpp>
@@ -166,5 +166,17 @@
         doTest(geoms, "GEOMETRYCOLLECTION (POINT (80 50), POINT (100 70), LINESTRING (40 60, 120 110))");
     }
 
+    template<>
+    template<>
+    void object::test<6>()
+    {
+        static char const* const geoms[] = 
+        {
+            "LINESTRING (0 0, 10 0, 5 -5, 5 5)",
+            NULL
+        };
+        doTest(geoms, "MULTILINESTRING ((0 0, 5 0), (5 0, 10 0, 5 -5, 5 0), (5 0, 5 5))");
+    }
+
 } // namespace tut
 
Modified: trunk/tests/xmltester/tests/general/TestUnaryUnion.xml
===================================================================
--- trunk/tests/xmltester/tests/general/TestUnaryUnion.xml	2011-11-04 17:45:43 UTC (rev 3513)
+++ trunk/tests/xmltester/tests/general/TestUnaryUnion.xml	2011-11-04 17:59:22 UTC (rev 3514)
@@ -27,6 +27,18 @@
 </case>
 
 <case>
+  <desc>L - LineString (showing noding)</desc>
+  <a>
+    LINESTRING (0 0, 10 0, 5 -5, 5 5)
+  </a>
+<test>
+  <op name="union" arg1="A">
+    MULTILINESTRING ((0 0, 5 0), (5 0, 10 0, 5 -5, 5 0), (5 0, 5 5))
+  </op>
+</test>
+</case>
+
+<case>
   <desc>mL - multiLineString (showing noding)</desc>
   <a>
     MULTILINESTRING((0 0, 10 10), (0 10, 10 0))
    
    
More information about the geos-commits
mailing list