[fdo-commits] r91 - trunk/Providers/WFS/Src/Provider
svn_fdo at osgeo.org
svn_fdo at osgeo.org
Wed Jan 24 15:48:08 EST 2007
Author: romicadascalescu
Date: 2007-01-24 15:48:08 -0500 (Wed, 24 Jan 2007)
New Revision: 91
Modified:
trunk/Providers/WFS/Src/Provider/FdoWfsConnection.cpp
Log:
Fixed WFS: Unexpected feature class appears as non abstract
Modified: trunk/Providers/WFS/Src/Provider/FdoWfsConnection.cpp
===================================================================
--- trunk/Providers/WFS/Src/Provider/FdoWfsConnection.cpp 2007-01-24 20:47:42 UTC (rev 90)
+++ trunk/Providers/WFS/Src/Provider/FdoWfsConnection.cpp 2007-01-24 20:48:08 UTC (rev 91)
@@ -347,6 +347,8 @@
continue;
}
+ FdoPtr<FdoWfsFeatureTypeList> pFeatList = mServiceMetadata->GetFeatureTypeList();
+ FdoPtr<FdoWfsFeatureTypeCollection> pFeatColl = pFeatList->GetFeatureTypes();
bool bNameModified = false;
for (int j = classes->GetCount() - 1; j >= 0; j--) {
FdoPtr<FdoClassDefinition> classDef = classes->GetItem(j);
@@ -382,17 +384,6 @@
break;
classMapping = NULL;
}
- // Prepare for implementation of #4
- FdoPtr<FdoWfsFeatureTypeList> pFeatList = mServiceMetadata->GetFeatureTypeList();
- FdoPtr<FdoWfsFeatureTypeCollection> pFeatColl = pFeatList->GetFeatureTypes();
- FdoPtr<FdoWfsFeatureType> pFeat = pFeatColl->FindItem(classDef->GetName());
- if (pFeat == NULL)
- {
- FdoStringP NameFeat = schema->GetName();
- NameFeat += L":";
- NameFeat += classDef->GetName();
- pFeat = pFeatColl->FindItem(NameFeat);
- }
FdoPtr<FdoPropertyDefinitionCollection> props = classDef->GetProperties();
FdoPtr<FdoXmlElementMappingCollection> elements;
@@ -429,13 +420,6 @@
ids->Add(dataProp);
continue; // no need to do the left adjustments
}
- // Doing #4
- if (prop->GetPropertyType() == FdoPropertyType_GeometricProperty && pFeat != NULL)
- {
- FdoGeometricPropertyDefinition* pPropGeom = static_cast<FdoGeometricPropertyDefinition*>(prop.p);
- if (pPropGeom != NULL && pPropGeom->GetSpatialContextAssociation() == NULL)
- pPropGeom->SetSpatialContextAssociation(pFeat->GetSRS());
- }
// Doing #5
if (elements != NULL)
@@ -519,8 +503,6 @@
props->RemoveAt(k);
// then add another new geometry property with the same name
FdoPtr<FdoGeometricPropertyDefinition> newGeoProp = FdoGeometricPropertyDefinition::Create(prop->GetName(), prop->GetDescription());
- if (pFeat != NULL)
- newGeoProp->SetSpatialContextAssociation(pFeat->GetSRS());
props->Add(newGeoProp);
// and we still have to change the element mapping's class mapping
FdoPtr<FdoXmlClassMapping> elementClass = FdoXmlClassMapping::Create(FdoGml212::mGeometryProperty,
@@ -580,8 +562,6 @@
// then add another new geometry property with the same name
FdoPtr<FdoGeometricPropertyDefinition> newGeoProp = FdoGeometricPropertyDefinition::Create(L"GEOMETRY", FdoGml212::mGeometryProperty);
newGeoProp->SetGeometryTypes(pNewTypeGeom);
- if (pFeat != NULL)
- newGeoProp->SetSpatialContextAssociation(pFeat->GetSRS());
props->Add(newGeoProp);
}
if (bNameModified)
@@ -612,6 +592,37 @@
_setClassDescription (classDef);
} // end of for each class
+ // this step at the end - after we cleaned the class
+ for (int j = classes->GetCount() - 1; j >= 0; j--)
+ {
+ FdoPtr<FdoClassDefinition> classDef = classes->GetItem(j);
+ // Prepare for implementation of #4
+ FdoPtr<FdoWfsFeatureType> pFeat = pFeatColl->FindItem(classDef->GetName());
+ if (pFeat == NULL)
+ {
+ FdoStringP NameFeat = schema->GetName();
+ NameFeat += L":";
+ NameFeat += classDef->GetName();
+ pFeat = pFeatColl->FindItem(NameFeat);
+ }
+ if (pFeat != NULL)
+ {
+ FdoPtr<FdoPropertyDefinitionCollection> props = classDef->GetProperties();
+ for (int k = props->GetCount() - 1; k >= 0; k--)
+ {
+ FdoPtr<FdoPropertyDefinition> prop = props->GetItem(k);
+ // Doing #4
+ if (prop->GetPropertyType() == FdoPropertyType_GeometricProperty)
+ {
+ FdoGeometricPropertyDefinition* pPropGeom = static_cast<FdoGeometricPropertyDefinition*>(prop.p);
+ if (pPropGeom != NULL && pPropGeom->GetSpatialContextAssociation() == NULL)
+ pPropGeom->SetSpatialContextAssociation(pFeat->GetSRS());
+ }
+ }
+ }
+ else
+ classDef->SetIsAbstract(true);
+ }
}// end of for each schema
}
return FDO_SAFE_ADDREF(mSchemas.p);
More information about the fdo-commits
mailing list