[fdo-commits] r2668 - trunk/Providers/SDF/Src/Provider
svn_fdo at osgeo.org
svn_fdo at osgeo.org
Fri Mar 9 14:06:24 EST 2007
Author: badreddinekaroui
Date: 2007-03-09 14:06:24 -0500 (Fri, 09 Mar 2007)
New Revision: 2668
Modified:
trunk/Providers/SDF/Src/Provider/SdfQueryOptimizer.cpp
trunk/Providers/SDF/Src/Provider/SdfSelect.cpp
Log:
Merge ticket #21 fix from 2.1.1 branch to the trunk
Modified: trunk/Providers/SDF/Src/Provider/SdfQueryOptimizer.cpp
===================================================================
--- trunk/Providers/SDF/Src/Provider/SdfQueryOptimizer.cpp 2007-03-09 19:06:03 UTC (rev 2667)
+++ trunk/Providers/SDF/Src/Provider/SdfQueryOptimizer.cpp 2007-03-09 19:06:24 UTC (rev 2668)
@@ -153,11 +153,21 @@
//update optimized query also by pushing
//the old filter -- it could not be optimized
m_filters.push_back(FDO_SAFE_ADDREF(&filter));
- fLeft->Release();
- delete argLeft;
+ if( fLeft != NULL )
+ fLeft->Release();
+
return;
}
+ if( filter.GetOperation() == FdoBinaryLogicalOperations_And && argLeft != NULL && argLeft->size() > 0 && fLeft == NULL )
+ {
+ // The left side reduced the condidate list to a smaller set and optimized away the left filter
+ // We only need to apply the right filter to the reduced set.
+ m_filters.push_back( right.Detach() );
+ m_retvals.push_back(argLeft);
+ return;
+ }
+
//evaluate right hand side
right->Process(this);
@@ -406,9 +416,11 @@
//by returning only features whose bounding boxes intersect with the
//bounding box of the input. The actual query result is guaranteed
//to be a subset of the R-Tree search.
- else if ( filter.GetOperation() == FdoSpatialOperations_Intersects
+ else if ( filter.GetOperation() == FdoSpatialOperations_Intersects
|| filter.GetOperation() == FdoSpatialOperations_Contains
- || filter.GetOperation() == FdoSpatialOperations_Within)
+ || filter.GetOperation() == FdoSpatialOperations_Within
+ || filter.GetOperation() == FdoSpatialOperations_Inside
+ || filter.GetOperation() == FdoSpatialOperations_Crosses )
{
FdoPtr<FdoFgfGeometryFactory> gf = FdoFgfGeometryFactory::GetInstance();
@@ -417,7 +429,7 @@
Bounds bounds;
FdoSpatialUtility::GetExtents(fgf, bounds.minx, bounds.miny, bounds.maxx, bounds.maxy);
- if (bounds.maxx >= bounds.minx && bounds.maxy >= bounds.miny)
+ if (bounds.maxx >= bounds.minx && bounds.maxy >= bounds.miny )
{
//expand a little to catch point features that lie exactly on the bounds
Bounds bounds2(bounds.minx - SDF_GLOBAL_TOLERANCE,
Modified: trunk/Providers/SDF/Src/Provider/SdfSelect.cpp
===================================================================
--- trunk/Providers/SDF/Src/Provider/SdfSelect.cpp 2007-03-09 19:06:03 UTC (rev 2667)
+++ trunk/Providers/SDF/Src/Provider/SdfSelect.cpp 2007-03-09 19:06:24 UTC (rev 2668)
@@ -121,6 +121,10 @@
FdoPtr<FdoIFilterCapabilities> filterCaps = m_connection->GetFilterCapabilities();
FdoCommonFilterExecutor::ValidateFilter( clas, m_filter, m_properties, filterCaps );
+
+ FdoFilter* newFilter = FdoCommonFilterExecutor::OptimizeFilter( m_filter );
+ FDO_SAFE_RELEASE(m_filter);
+ m_filter = newFilter;
}
//get the R-Tree for this feature class...
More information about the fdo-commits
mailing list