/*
* GeoTools - The Open Source Java GIS Toolkit
* http://geotools.org
*
* (C) 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.geotools.xacml.geoxacml.cond;
import java.util.List;
import org.geotools.xacml.geoxacml.attr.GeometryAttribute;
import com.sun.xacml.EvaluationCtx;
import com.sun.xacml.attr.AttributeValue;
import com.sun.xacml.cond.EvaluationResult;
import com.sun.xacml.cond.Expression;
import com.vividsolutions.jts.geom.Geometry;
import com.vividsolutions.jts.geom.LineString;
import com.vividsolutions.jts.geom.MultiLineString;
import com.vividsolutions.jts.geom.MultiPoint;
import com.vividsolutions.jts.geom.Point;
/**
* Check if a geometry is closed
*
* @author Christian Mueller
*
*/
public class GeometryIsClosed extends GeometryCheckFunction {
public static final String NAME = NAME_PREFIX + "geometry-is-closed";
public GeometryIsClosed() {
super(NAME);
}
public EvaluationResult evaluate(List<? extends Expression> inputs, EvaluationCtx context) {
AttributeValue[] argValues = new AttributeValue[inputs.size()];
EvaluationResult result = evalArgs(inputs, context, argValues);
if (result != null)
return result;
GeometryAttribute geomAttr = (GeometryAttribute) (argValues[0]);
boolean evalResult = false;
try {
Geometry geom = geomAttr.getGeometry();
if (geom.isEmpty())
evalResult = true;
else if (geom instanceof Point || geom instanceof MultiPoint)
evalResult = true;
else if (geom instanceof LineString)
evalResult = ((LineString) geom).isClosed();
else if (geom instanceof MultiLineString)
evalResult = ((MultiLineString) geom).isClosed();
else
evalResult = false;
// evalResult= geom.getBoundary().isEmpty();
} catch (Throwable t) {
return exceptionError(t);
}
return EvaluationResult.getInstance(evalResult);
}
}