break; case CONTAINS: propertyName = ( (Contains) operator ).getPropName(); geometry = ( (Contains) operator ).getGeometry(); break; case CROSSES:
@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.contains( transformedLiteral ); } } return false; }
case CONTAINS: Contains contains = (Contains) op; return new Contains( copy( contains.getPropName() ), contains.getGeometry() ); case CROSSES: Crosses crosses = (Crosses) op;
break; case CONTAINS: geometry = ( (Contains) operator ).getGeometry(); break; case CROSSES:
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 Contains( param1, param2 ); break;
Contains contains = (Contains) op; builder.add( propNameExpr ).add( ".STContains(" ); builder.add( toProtoSQL( contains.getGeometry(), storageCRS, srid ) ); builder.add( ")=1" ); break;
return new Beyond( (Expression) os[0], (Geometry) os[1], b.getDistance() ); case CONTAINS: return new Contains( (Expression) os[0], (Geometry) os[1] ); case CROSSES: return new Crosses( (Expression) os[0], (Geometry) os[1] );
builder.add( toProtoSQL( contains.getGeometry(), storageCRS, srid ) ); builder.add( ")" ); break;
spatialOperator = new Contains( param1, param2 ); break;
spatialOperator = new Contains( param1, param2 ); break;