org.eclipse.rdf4j.sail.SailConnectionTupleQuery Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of rdf4j-sail-spin Show documentation
Show all versions of rdf4j-sail-spin Show documentation
The SPIN SAIL adds constraint checking and inferencing using SPIN to a base SAIL.
/*******************************************************************************
* Copyright (c) 2015 Eclipse RDF4J contributors, Aduna, and others.
* 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.
*******************************************************************************/
package org.eclipse.rdf4j.sail;
import java.util.ArrayList;
import org.eclipse.rdf4j.common.iteration.CloseableIteration;
import org.eclipse.rdf4j.query.BindingSet;
import org.eclipse.rdf4j.query.QueryEvaluationException;
import org.eclipse.rdf4j.query.QueryResults;
import org.eclipse.rdf4j.query.TupleQuery;
import org.eclipse.rdf4j.query.TupleQueryResult;
import org.eclipse.rdf4j.query.TupleQueryResultHandler;
import org.eclipse.rdf4j.query.TupleQueryResultHandlerException;
import org.eclipse.rdf4j.query.algebra.TupleExpr;
import org.eclipse.rdf4j.query.impl.TupleQueryResultImpl;
import org.eclipse.rdf4j.query.parser.ParsedTupleQuery;
/**
* @author Arjohn Kampman
*/
public class SailConnectionTupleQuery extends SailConnectionQuery implements TupleQuery {
public SailConnectionTupleQuery(ParsedTupleQuery tupleQuery, SailConnection sailConnection) {
super(tupleQuery, sailConnection);
}
@Override
public ParsedTupleQuery getParsedQuery() {
return (ParsedTupleQuery) super.getParsedQuery();
}
@Override
public TupleQueryResult evaluate() throws QueryEvaluationException {
TupleExpr tupleExpr = getParsedQuery().getTupleExpr();
try {
CloseableIteration extends BindingSet, QueryEvaluationException> bindingsIter;
SailConnection sailCon = getSailConnection();
bindingsIter = sailCon.evaluate(tupleExpr, getActiveDataset(), getBindings(), getIncludeInferred());
bindingsIter = enforceMaxQueryTime(bindingsIter);
return new TupleQueryResultImpl(new ArrayList<>(tupleExpr.getBindingNames()), bindingsIter);
} catch (SailException e) {
throw new QueryEvaluationException(e.getMessage(), e);
}
}
@Override
public void evaluate(TupleQueryResultHandler handler)
throws QueryEvaluationException, TupleQueryResultHandlerException {
TupleQueryResult queryResult = evaluate();
QueryResults.report(queryResult, handler);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy