break; case EQUALS: geometry = ( (Equals) operator ).getGeometry(); break; case INTERSECTS:
break; case EQUALS: propertyName = ( (Equals) operator ).getPropName(); geometry = ( (Equals) operator ).getGeometry(); break; case INTERSECTS:
@Override public <T> boolean evaluate( T obj, XPathEvaluator<T> xpathEvaluator ) throws FilterEvaluationException { for ( TypedObjectNode paramValue : propName.evaluate( obj, xpathEvaluator ) ) { Geometry geom = checkGeometryOrNull( paramValue ); if ( geom != null ) { Geometry transformedLiteral = getCompatibleGeometry( geom, geometry ); return geom.equals( transformedLiteral ); } } return false; }
case EQUALS: Equals equals = (Equals) op; return new Equals( copy( equals.getPropName() ), equals.getGeometry() ); case INTERSECTS: Intersects intersects = (Intersects) op;
private static BBOX extractBBox( SpatialOperator oper ) { SubType type = oper.getSubType(); switch ( type ) { case BBOX: return (BBOX) oper; case CONTAINS: // Oracle does not like zero-extent bboxes if ( !( ( (Contains) oper ).getGeometry() instanceof Point ) ) return new BBOX( ( (Contains) oper ).getParam1(), ( (Contains) oper ).getGeometry().getEnvelope() ); return null; case CROSSES: return new BBOX( ( (Crosses) oper ).getParam1(), ( (Crosses) oper ).getGeometry().getEnvelope() ); case DWITHIN: // TOOD use enlarged bbox return null; case EQUALS: return new BBOX( ( (Equals) oper ).getParam1(), ( (Equals) oper ).getGeometry().getEnvelope() ); case INTERSECTS: return new BBOX( ( (Intersects) oper ).getParam1(), ( (Intersects) oper ).getGeometry().getEnvelope() ); case OVERLAPS: return new BBOX( ( (Overlaps) oper ).getParam1(), ( (Overlaps) oper ).getGeometry().getEnvelope() ); case WITHIN: return new BBOX( ( (Within) oper ).getParam1(), ( (Within) oper ).getGeometry().getEnvelope() ); default: { return null; } } }
spatialOperator = new Equals( param1, param2 ); break;
return new DWithin( (Expression) os[0], (Geometry) os[1], d.getDistance() ); case EQUALS: return new Equals( (Expression) os[0], (Geometry) os[1] ); case INTERSECTS: return new Intersects( (Expression) os[0], (Geometry) os[1] );
Equals equals = (Equals) op; builder.add( propNameExpr ).add( ".STEquals(" ); builder.add( toProtoSQL( equals.getGeometry(), storageCRS, srid ) ); builder.add( ")=1" ); break;
spatialOperator = new Equals( param1, param2 ); break;
builder.add( toProtoSQL( equals.getGeometry(), storageCRS, srid ) ); builder.add( ")" ); break;
spatialOperator = new Equals( param1, param2 ); break;