ExtendedEvaluationStrategy.java
/*******************************************************************************
* Copyright (c) 2016 Eclipse RDF4J contributors.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Distribution License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: BSD-3-Clause
*******************************************************************************/
package org.eclipse.rdf4j.query.algebra.evaluation.impl;
import org.eclipse.rdf4j.common.transaction.QueryEvaluationMode;
import org.eclipse.rdf4j.model.Literal;
import org.eclipse.rdf4j.model.Value;
import org.eclipse.rdf4j.model.impl.BooleanLiteral;
import org.eclipse.rdf4j.query.BindingSet;
import org.eclipse.rdf4j.query.Dataset;
import org.eclipse.rdf4j.query.QueryEvaluationException;
import org.eclipse.rdf4j.query.algebra.Compare;
import org.eclipse.rdf4j.query.algebra.MathExpr;
import org.eclipse.rdf4j.query.algebra.evaluation.QueryValueEvaluationStep;
import org.eclipse.rdf4j.query.algebra.evaluation.TripleSource;
import org.eclipse.rdf4j.query.algebra.evaluation.ValueExprEvaluationException;
import org.eclipse.rdf4j.query.algebra.evaluation.federation.FederatedServiceResolver;
import org.eclipse.rdf4j.query.algebra.evaluation.util.QueryEvaluationUtil;
import org.eclipse.rdf4j.query.algebra.evaluation.util.XMLDatatypeMathUtil;
/**
* SPARQL 1.1 extended query evaluation strategy. This strategy adds the use of virtual properties, as well as extended
* comparison and mathematical operators to the minimally-conforming {@link StrictEvaluationStrategy}.
*
* @author Jeen Broekstra
* @deprecated Use {@link DefaultEvaluationStrategy} instead.
*/
@Deprecated(since = "4.3.0", forRemoval = true)
public class ExtendedEvaluationStrategy extends TupleFunctionEvaluationStrategy {
public ExtendedEvaluationStrategy(TripleSource tripleSource, Dataset dataset,
FederatedServiceResolver serviceResolver, long iterationCacheSyncThreshold,
EvaluationStatistics evaluationStatistics) {
super(tripleSource, dataset, serviceResolver, iterationCacheSyncThreshold, evaluationStatistics);
this.setQueryEvaluationMode(QueryEvaluationMode.STANDARD);
}
@Deprecated(forRemoval = true)
@Override
public Value evaluate(Compare node, BindingSet bindings)
throws QueryEvaluationException {
Value leftVal = evaluate(node.getLeftArg(), bindings);
Value rightVal = evaluate(node.getRightArg(), bindings);
// return result of non-strict comparisson.
return BooleanLiteral.valueOf(QueryEvaluationUtil.compare(leftVal, rightVal, node.getOperator(), false));
}
@Override
protected QueryValueEvaluationStep prepare(Compare node, QueryEvaluationContext context) {
return supplyBinaryValueEvaluation(node, (leftVal, rightVal) -> BooleanLiteral
.valueOf(QueryEvaluationUtil.compare(leftVal, rightVal, node.getOperator(), false)), context);
}
@Deprecated(forRemoval = true)
@Override
public Value evaluate(MathExpr node, BindingSet bindings)
throws QueryEvaluationException {
Value leftVal = evaluate(node.getLeftArg(), bindings);
Value rightVal = evaluate(node.getRightArg(), bindings);
return mathOperationApplier(node, leftVal, rightVal);
}
private Value mathOperationApplier(MathExpr node, Value leftVal, Value rightVal) {
if (leftVal.isLiteral() && rightVal.isLiteral()) {
return XMLDatatypeMathUtil.compute((Literal) leftVal, (Literal) rightVal, node.getOperator());
}
throw new ValueExprEvaluationException("Both arguments must be literals");
}
@Override
protected QueryValueEvaluationStep prepare(MathExpr node, QueryEvaluationContext context) {
return supplyBinaryValueEvaluation(node, (leftVal, rightVal) -> mathOperationApplier(node, leftVal, rightVal),
context);
}
}