/** * The contents of this file are subject to the Open Software License * Version 3.0 (the "License"); you may not use this file except in * compliance with the License. You may obtain a copy of the License at * http://www.opensource.org/licenses/osl-3.0.txt * * Software distributed under the License is distributed on an "AS IS" * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See * the License for the specific language governing rights and limitations * under the License. */ package org.mulgara.query.filter; import org.mulgara.query.QueryException; import org.mulgara.query.filter.value.Bool; /** * Describes a test function on an RDFTerm. * * @created Mar 17, 2008 * @author Paula Gearon * @copyright © 2008 <a href="mailto:pgearon@users.sourceforge.net">Paula Gearon</a> * @licence <a href="{@docRoot}/../../LICENCE.txt">Open Software License v3.0</a> */ public abstract class AbstractBooleanFn extends AbstractFilterValue implements Filter { /** Serialization ID */ private static final long serialVersionUID = -5045050008524194860L; /** The variable to test */ RDFTerm operand; /** * Create a function for testing a term * @param operand The term to test */ public AbstractBooleanFn(RDFTerm operand) { super(operand); this.operand = operand; } /** * @see org.mulgara.query.filter.Filter#test(Context) */ public boolean test(Context context) throws QueryException { setCurrentContext(context); return fnTest(); } /** @see org.mulgara.query.filter.AbstractFilterValue#resolve() */ protected RDFTerm resolve() throws QueryException { return fnTest() ? Bool.TRUE : Bool.FALSE; } /** * An implementation specific test * @return <code>true</code> when this test passes. * @throws QueryException Thrown when an error occurs while trying to resolve the value of the operand. */ abstract boolean fnTest() throws QueryException; }