/* * Geotoolkit - An Open Source Java GIS Toolkit * http://www.geotoolkit.org * * (C) 2005-2008, Open Source Geospatial Foundation (OSGeo) * * 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; * version 2.1 of the License. * * 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. */ package org.geotoolkit.filter.function.other; import com.vividsolutions.jts.geom.Geometry; import org.geotoolkit.filter.function.AbstractFunction; import org.opengis.filter.expression.Expression; public class EqualsExactToleranceFunction extends AbstractFunction { public EqualsExactToleranceFunction(final Expression expr1, final Expression expr2, final Expression expr3) { super(OtherFunctionFactory.EQUALS_EXACT_TOLERANCE, new Expression[]{expr1,expr2,expr3}, null); } @Override public Object evaluate(final Object feature) { Geometry arg0; Geometry arg1; double arg2; try { // attempt to get value and perform conversion arg0 = (Geometry) parameters.get(0).evaluate(feature); } catch (Exception e) // probably a type error { throw new IllegalArgumentException( "Filter Function problem for function equalsExactTolerance argument #0 - expected type Geometry"); } try { // attempt to get value and perform conversion arg1 = (Geometry) parameters.get(1).evaluate(feature); } catch (Exception e) // probably a type error { throw new IllegalArgumentException( "Filter Function problem for function equalsExactTolerance argument #1 - expected type Geometry"); } try { // attempt to get value and perform conversion arg2 = ((Number) parameters.get(2).evaluate(feature)).doubleValue(); } catch (Exception e) // probably a type error { throw new IllegalArgumentException( "Filter Function problem for function equalsExactTolerance argument #2 - expected type double"); } return StaticUtils.equalsExactTolerance(arg0, arg1, arg2); } }