[fdo-commits] r2551 - in trunk/Fdo: UnitTest Unmanaged/Src/Fdo/Xml

svn_fdo at osgeo.org svn_fdo at osgeo.org
Fri Feb 16 14:55:34 EST 2007


Author: brentrobinson
Date: 2007-02-16 14:55:34 -0500 (Fri, 16 Feb 2007)
New Revision: 2551

Modified:
   trunk/Fdo/UnitTest/SpatialContextTest.cpp
   trunk/Fdo/UnitTest/SpatialContextTest.h
   trunk/Fdo/Unmanaged/Src/Fdo/Xml/SCReadHandler.cpp
   trunk/Fdo/Unmanaged/Src/Fdo/Xml/SCReadHandler.h
   trunk/Fdo/Unmanaged/Src/Fdo/Xml/SpatialContextReader.cpp
Log:
Ticket#9: FdoXmlSpatialContextReader: Prevent ':' encoding


Modified: trunk/Fdo/UnitTest/SpatialContextTest.cpp
===================================================================
--- trunk/Fdo/UnitTest/SpatialContextTest.cpp	2007-02-16 18:43:18 UTC (rev 2550)
+++ trunk/Fdo/UnitTest/SpatialContextTest.cpp	2007-02-16 19:55:34 UTC (rev 2551)
@@ -103,7 +103,7 @@
             bFailed = true;
         }
         if ( !bFailed ) 
-            CPPUNIT_FAIL( "Writing nameless spatial context should have failed." );
+            CPPUNIT_FAIL( "Writing extentless spatial context should have failed." );
 
         // now for the happy tests.
 
@@ -332,6 +332,59 @@
     }
 }
 
+void SpatialContextTest::testXmlDotColon()
+{
+    try {
+        FdoInt32 pass;
+
+        // pass 0 writes SC without WKT, pass1 writes it with WKT.
+        for ( pass = 0; pass < 2; pass++ ) {
+            FdoIoMemoryStreamP stream = FdoIoMemoryStream::Create();
+            FdoIoMemoryStreamP stream2 = FdoIoMemoryStream::Create();
+            FdoXmlWriterP xmlWriter = FdoXmlWriter::Create(stream);
+
+            FdoXmlSpatialContextWriterP writer = FdoXmlSpatialContextWriter::Create( 
+                xmlWriter
+            );
+
+            writer->SetName( L"EPSG:123.4" );
+            writer->SetDescription( L". and : test" );
+            writer->SetCoordinateSystem( L"EPSG:1234" );
+            if ( pass == 1 ) 
+                writer->SetCoordinateSystemWkt( L"LOCAL_CS [ \"Non-Earth (Meter)\", LOCAL_DATUM [\"Local Datum\", 0], UNIT [\"Meter\", 1.0], AXIS [\"X\", EAST], AXIS[\"Y\", NORTH]]" );
+            FdoPtr<FdoByteArray> extent = SerializeExtent( 0, 0, 15000, 10000 );
+            writer->SetExtent( extent );
+            writer->SetExtentType( FdoSpatialContextExtentType_Dynamic );
+            writer->SetXYTolerance( 0.1 );
+            writer->SetZTolerance( 0.01 );
+
+            writer->WriteSpatialContext();
+
+            writer = NULL;
+            xmlWriter = NULL;
+            stream->Reset();
+
+            FdoXmlSpatialContextReaderP reader =
+                FdoXmlSpatialContextReader::Create(
+                    FdoXmlReaderP( FdoXmlReader::Create(stream) ),
+                    FdoXmlSpatialContextFlagsP(
+                        FdoXmlSpatialContextFlags::Create( NULL, FdoXmlFlags::ErrorLevel_High ) 
+                    )
+                );
+
+            FDO_CPPUNIT_ASSERT( reader->ReadNext() );
+            FDO_CPPUNIT_ASSERT( wcscmp(reader->GetName(), L"EPSG:123.4") == 0 );
+            FDO_CPPUNIT_ASSERT( wcscmp(reader->GetCoordinateSystem(), L"EPSG:1234") == 0 );
+            FDO_CPPUNIT_ASSERT( wcscmp(reader->GetDescription(), L". and : test") == 0 );
+         
+            FDO_CPPUNIT_ASSERT( !reader->ReadNext() );
+        }
+    }
+    catch ( FdoException* e ) {
+		UnitTestUtil::FailOnException( e );
+    }
+}
+
 FdoByteArray* SpatialContextTest::SerializeExtent( double minX, double minY, double maxX, double maxY )
 {
     // Create a byte array 

Modified: trunk/Fdo/UnitTest/SpatialContextTest.h
===================================================================
--- trunk/Fdo/UnitTest/SpatialContextTest.h	2007-02-16 18:43:18 UTC (rev 2550)
+++ trunk/Fdo/UnitTest/SpatialContextTest.h	2007-02-16 19:55:34 UTC (rev 2551)
@@ -27,6 +27,7 @@
     FDO_CPPUNIT_DEFINE(testXmlV2);
     FDO_CPPUNIT_DEFINE(testXmlError);
     FDO_CPPUNIT_DEFINE(testXmlNesting);
+    FDO_CPPUNIT_DEFINE(testXmlDotColon);
 
     CPPUNIT_TEST_SUITE(SpatialContextTest);
 
@@ -35,6 +36,7 @@
     CPPUNIT_TEST(testXmlV2);
     CPPUNIT_TEST(testXmlError);
     CPPUNIT_TEST(testXmlNesting);
+    CPPUNIT_TEST(testXmlDotColon);
 
     CPPUNIT_TEST_SUITE_END();
 
@@ -57,6 +59,9 @@
     // root element.
     void testXmlNesting();
 
+    // Test round-tripping spatial contexts with dots and/or colons in name and coordsys name,
+    void testXmlDotColon();
+
     // Convert extents from doubles to byte array
     FdoByteArray* SerializeExtent( double minX, double minY, double maxX, double maxY );
     // Deserialize spatial contexts from inStream and serialize them to outStream

Modified: trunk/Fdo/Unmanaged/Src/Fdo/Xml/SCReadHandler.cpp
===================================================================
--- trunk/Fdo/Unmanaged/Src/Fdo/Xml/SCReadHandler.cpp	2007-02-16 18:43:18 UTC (rev 2550)
+++ trunk/Fdo/Unmanaged/Src/Fdo/Xml/SCReadHandler.cpp	2007-02-16 19:55:34 UTC (rev 2551)
@@ -146,6 +146,22 @@
     mElementPrefix = L"";
 }
 
+FdoStringP FdoXmlSCReadHandler::DecodeName ( FdoStringP name, FdoXmlReader* reader )
+{
+    FdoStringP outName = name;
+    
+    if ( mXmlFlags->GetNameAdjust() ) {
+        //Workaround: '.' and ':' are not allowed in schema element names so DecodeName replaces
+        //them with '-dot-' and '-colon'. However '.' and ':' are allowed in spatial context names
+        //so change them back.
+        //The ideal fix is to move the '.' and ':' replacement up from FdoXmlReader to the 
+        //Fdo/Schema level but this would be a bit riskier and should be done in a later version.
+        outName = reader->DecodeName(name).Replace( L"-colon-", L":" ).Replace( L"-dot-", L"." );
+    }
+
+    return outName;
+}
+
 FdoXmlSaxHandler* FdoXmlSCReadHandler::doTransition( 
     FdoBoolean isStart, 
     FdoXmlSaxContext* context, 
@@ -337,9 +353,7 @@
         attr = atts->FindItem( FdoXml::mGmlUri + L":id" );
 
         if ( attr ) {
-            mID = mXmlFlags->GetNameAdjust() ?
-                (FdoString*) reader->DecodeName(attr->GetValue()) :
-                attr->GetValue();
+            mID = DecodeName( attr->GetValue(), reader );
         }
 
         break;
@@ -479,7 +493,7 @@
                     );
                 }
                 else {
-                    mCoordSysName = tokens->GetString(1);
+                    mCoordSysName = DecodeName( tokens->GetString(1), reader );
                 }
             }
         }
@@ -714,9 +728,7 @@
         attr = atts->FindItem( FdoXml::mGmlUri + L":id" );
 
         if ( attr ) {
-            mCsysID = mXmlFlags->GetNameAdjust() ?
-                (FdoString*) reader->DecodeName(attr->GetValue()) :
-                attr->GetValue();
+            mCsysID = DecodeName( attr->GetValue(), reader );
         }
 
         break;

Modified: trunk/Fdo/Unmanaged/Src/Fdo/Xml/SCReadHandler.h
===================================================================
--- trunk/Fdo/Unmanaged/Src/Fdo/Xml/SCReadHandler.h	2007-02-16 18:43:18 UTC (rev 2550)
+++ trunk/Fdo/Unmanaged/Src/Fdo/Xml/SCReadHandler.h	2007-02-16 19:55:34 UTC (rev 2551)
@@ -44,6 +44,8 @@
     // Initializes the handler. Must be called before reading each spatial context.
     void Setup( FdoXmlFlags* pXmlFlags );
 
+    // Decodes any escaped characters in Spatial Context and Coordinate System names. 
+    FdoStringP DecodeName ( FdoStringP name, FdoXmlReader* reader );
 
 protected:
     FdoXmlSCReadHandler() {}

Modified: trunk/Fdo/Unmanaged/Src/Fdo/Xml/SpatialContextReader.cpp
===================================================================
--- trunk/Fdo/Unmanaged/Src/Fdo/Xml/SpatialContextReader.cpp	2007-02-16 18:43:18 UTC (rev 2550)
+++ trunk/Fdo/Unmanaged/Src/Fdo/Xml/SpatialContextReader.cpp	2007-02-16 19:55:34 UTC (rev 2551)
@@ -160,10 +160,6 @@
         mExtent =  gf->GetFgf(geom);
         mSCHandler->mFirst = false;
 
-        // Decode the coordinate system name.
-        if ( mXmlFlags->GetNameAdjust() ) {
-            mSCHandler->mCoordSysName = mXmlReader->DecodeName( mSCHandler->mCoordSysName );
-        }
         return true;
     }
     else {



More information about the fdo-commits mailing list