/*
* The JTS Topology Suite is a collection of Java classes that
* implement the fundamental operations required to validate a given
* geo-spatial data set to a known topological specification.
*
* Copyright (C) 2001 Vivid Solutions
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* For more information, contact:
*
* Vivid Solutions
* Suite #1A
* 2328 Government Street
* Victoria BC V8T 5G5
* Canada
*
* (250)385-6040
* www.vividsolutions.com
*/
package com.revolsys.geometry.test.geomop;
import com.revolsys.geometry.model.Geometry;
import com.revolsys.geometry.test.testrunner.BooleanResult;
import com.revolsys.geometry.test.testrunner.Result;
/**
* A {@link GeometryOperation} which uses {@link PreparedGeometry}s
* for applicable operations.
* This allows testing correctness of the <tt>PreparedGeometry</tt> implementation.
* <p>
* This class can be used via the <tt>-geomop</tt> command-line option
* or by the <tt><geometryOperation></tt> XML test file setting.
*
* @author mbdavis
*
*/
public class PreparedGeometryOperation implements GeometryOperation {
static class PreparedGeometryOp {
public static boolean contains(final Geometry g1, final Geometry g2) {
final Geometry prepGeom = g1.prepare();
return prepGeom.contains(g2);
}
public static boolean containsProperly(final Geometry g1, final Geometry g2) {
final Geometry prepGeom = g1.prepare();
return prepGeom.containsProperly(g2);
}
public static boolean covers(final Geometry g1, final Geometry g2) {
final Geometry prepGeom = g1.prepare();
return prepGeom.covers(g2);
}
public static boolean intersects(final Geometry g1, final Geometry g2) {
final Geometry prepGeom = g1.prepare();
return prepGeom.intersects(g2);
}
}
private static boolean isPreparedOp(final String opName) {
if (opName.equals("intersects")) {
return true;
}
if (opName.equals("contains")) {
return true;
}
if (opName.equals("containsProperly")) {
return true;
}
if (opName.equals("covers")) {
return true;
}
return false;
}
private GeometryMethodOperation chainOp = new GeometryMethodOperation();
public PreparedGeometryOperation() {
}
/**
* Creates a new operation which chains to the given {@link GeometryMethodOperation}
* for non-intercepted methods.
*
* @param chainOp the operation to chain to
*/
public PreparedGeometryOperation(final GeometryMethodOperation chainOp) {
this.chainOp = chainOp;
}
@Override
public Class getReturnType(final String opName) {
if (isPreparedOp(opName)) {
return boolean.class;
}
return this.chainOp.getReturnType(opName);
}
/**
* Invokes the named operation
*
* @param opName
* @param geometry
* @param args
* @return the result
* @throws Exception
* @see GeometryOperation#invoke
*/
@Override
public Result invoke(final String opName, final Geometry geometry, final Object[] args)
throws Exception {
if (!isPreparedOp(opName)) {
return this.chainOp.invoke(opName, geometry, args);
}
return invokePreparedOp(opName, geometry, args);
}
private Result invokePreparedOp(final String opName, final Geometry geometry,
final Object[] args) {
final Geometry g2 = (Geometry)args[0];
if (opName.equals("intersects")) {
return new BooleanResult(PreparedGeometryOp.intersects(geometry, g2));
}
if (opName.equals("contains")) {
return new BooleanResult(PreparedGeometryOp.contains(geometry, g2));
}
if (opName.equals("containsProperly")) {
return new BooleanResult(PreparedGeometryOp.containsProperly(geometry, g2));
}
if (opName.equals("covers")) {
return new BooleanResult(PreparedGeometryOp.covers(geometry, g2));
}
return null;
}
}