blob: ae1e9aa0439b90ef73634c63ab4d331bda4e4d2a [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.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.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.jena.arq.querybuilder;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import org.apache.jena.arq.querybuilder.clauses.DatasetClause;
import org.apache.jena.arq.querybuilder.clauses.SolutionModifierClause;
import org.apache.jena.arq.querybuilder.clauses.WhereClause;
import org.apache.jena.arq.querybuilder.handlers.DatasetHandler;
import org.apache.jena.arq.querybuilder.handlers.HandlerBlock;
import org.apache.jena.arq.querybuilder.handlers.SolutionModifierHandler;
import org.apache.jena.graph.FrontsTriple;
import org.apache.jena.graph.Node;
import org.apache.jena.graph.Triple;
import org.apache.jena.query.SortCondition;
import org.apache.jena.sparql.core.TriplePath;
import org.apache.jena.sparql.core.Var;
import org.apache.jena.sparql.expr.Expr;
/**
* Builder for SPARQL Ask Queries.
* <p>
* The AskBuilder provides chainable methods to programmatically generate SPARQL
* Ask Queries. The application order of the methods is not relevant for the
* resulting query. An {@link ExprFactory} is intended for use along with the
* AskBuilder to generate needed {@link Expr} parameter values. An
* {@link ExprFactory} that works with the same prefixes can be obtained with
* {@link AskBuilder#getExprFactory()}.
* <p>
* The AskBuilder can be used as <b>prepared query</b>. Values for variables in
* the created query can be set with {@link AskBuilder#setVar(Object, Object)}
* and {@link AskBuilder#setVar(Var, Node)}. The method
* {@link AskBuilder#clearWhereValues()} allows to clear the set values.
*
* @see ConstructBuilder
* @see DescribeBuilder
* @see SelectBuilder
* @see UpdateBuilder
*/
public class AskBuilder extends AbstractQueryBuilder<AskBuilder>
implements DatasetClause<AskBuilder>, WhereClause<AskBuilder>, SolutionModifierClause<AskBuilder> {
private final HandlerBlock handlerBlock;
public AskBuilder() {
super();
query.setQueryAskType();
handlerBlock = new HandlerBlock(query);
}
@Override
public HandlerBlock getHandlerBlock() {
return handlerBlock;
}
@Override
public DatasetHandler getDatasetHandler() {
return handlerBlock.getDatasetHandler();
}
@Override
public AskBuilder clone() {
AskBuilder qb = new AskBuilder();
qb.handlerBlock.addAll(handlerBlock);
return qb;
}
@Override
public AskBuilder fromNamed(Object graphName) {
getDatasetHandler().fromNamed(graphName);
return this;
}
@Override
public AskBuilder from(Object graphName) {
getDatasetHandler().from(graphName);
return this;
}
@Override
public AskBuilder addWhere(TriplePath t) {
getWhereHandler().addWhere(t);
return this;
}
@Override
public AskBuilder addWhere(Collection<TriplePath> collection) {
getWhereHandler().addWhere(collection);
return this;
}
@Override
public AskBuilder addWhere(Triple t) {
getWhereHandler().addWhere(new TriplePath(t));
return this;
}
@Override
public AskBuilder addWhere(FrontsTriple t) {
getWhereHandler().addWhere(new TriplePath(t.asTriple()));
return this;
}
@Override
public AskBuilder addWhere(Object s, Object p, Object o) {
getWhereHandler().addWhere(makeTriplePaths(s, p, o));
return this;
}
@Override
public AskBuilder addWhereValueVar(Object var) {
getWhereHandler().addValueVar(getPrologHandler().getPrefixes(), var);
return this;
}
@Override
public AskBuilder addWhereValueVar(Object var, Object... values) {
getWhereHandler().addValueVar(getPrologHandler().getPrefixes(), var, values);
return this;
}
@Override
public <K extends Collection<?>> AskBuilder addWhereValueVars(Map<?, K> dataTable) {
getWhereHandler().addValueVars(getPrologHandler().getPrefixes(), dataTable);
return this;
}
@Override
public AskBuilder addWhereValueRow(Object... values) {
getWhereHandler().addValueRow(getPrologHandler().getPrefixes(), values);
return this;
}
@Override
public AskBuilder addWhereValueRow(Collection<?> values) {
getWhereHandler().addValueRow(getPrologHandler().getPrefixes(), values);
return this;
}
@Override
public List<Var> getWhereValuesVars() {
return getWhereHandler().getValuesVars();
}
@Override
public Map<Var, List<Node>> getWhereValuesMap() {
return getWhereHandler().getValuesMap();
}
@Override
public AskBuilder clearWhereValues() {
getWhereHandler().clearValues();
return this;
}
@Override
public AskBuilder addOptional(TriplePath t) {
getWhereHandler().addOptional(t);
return this;
}
@Override
public AskBuilder addOptional(Triple t) {
return addOptional(new TriplePath(t));
}
@Override
public AskBuilder addOptional(AbstractQueryBuilder<?> t) {
getWhereHandler().addOptional(t.getWhereHandler());
return this;
}
@Override
public AskBuilder addOptional(Collection<TriplePath> collection) {
getWhereHandler().addOptional(collection);
return this;
}
@Override
public AskBuilder addOptional(FrontsTriple t) {
return addOptional(new TriplePath(t.asTriple()));
}
@Override
public AskBuilder addOptional(Object s, Object p, Object o) {
getWhereHandler().addOptional(makeTriplePaths(s, p, o));
return this;
}
@Override
public AskBuilder addFilter(Expr expr) {
getWhereHandler().addFilter(expr);
return this;
}
@Override
public AskBuilder addFilter(String s) {
getWhereHandler().addFilter(s);
return this;
}
@Override
public AskBuilder addSubQuery(AbstractQueryBuilder<?> subQuery) {
getWhereHandler().addSubQuery(subQuery);
return this;
}
@Override
public AskBuilder addUnion(AbstractQueryBuilder<?> subQuery) {
getWhereHandler().addUnion(subQuery);
return this;
}
@Override
public AskBuilder addGraph(Object graph, AbstractQueryBuilder<?> subQuery) {
getPrologHandler().addAll(subQuery.getPrologHandler());
getWhereHandler().addGraph(makeNode(graph), subQuery.getWhereHandler());
return this;
}
@Override
public AskBuilder addGraph(Object graph, FrontsTriple triple) {
addGraph(graph, new TriplePath(triple.asTriple()));
return this;
}
@Override
public AskBuilder addGraph(Object graph, Object subject, Object predicate, Object object) {
getWhereHandler().addGraph(makeNode(graph), makeTriplePaths(subject, predicate, object));
return this;
}
@Override
public AskBuilder addGraph(Object graph, Triple triple) {
addGraph(graph, new TriplePath(triple));
return this;
}
@Override
public AskBuilder addGraph(Object graph, TriplePath triplePath) {
getWhereHandler().addGraph(makeNode(graph), triplePath);
return this;
}
@Override
public AskBuilder addGraph(Object graph, Collection<TriplePath> collection) {
getWhereHandler().addGraph(makeNode(graph), collection);
return this;
}
@Override
public AskBuilder addBind(Expr expression, Object var) {
getWhereHandler().addBind(expression, Converters.makeVar(var));
return this;
}
@Override
public AskBuilder addBind(String expression, Object var) {
getWhereHandler().addBind(expression, Converters.makeVar(var));
return this;
}
@Override
public AskBuilder addOrderBy(Expr orderBy) {
getSolutionModifierHandler().addOrderBy(orderBy);
return this;
}
@Override
public AskBuilder addOrderBy(Object orderBy) {
getSolutionModifierHandler().addOrderBy(Converters.makeVar(orderBy));
return this;
}
@Override
public AskBuilder addOrderBy(SortCondition orderBy) {
getSolutionModifierHandler().addOrderBy(orderBy);
return this;
}
@Override
public AskBuilder addOrderBy(Expr orderBy, Order order) {
getSolutionModifierHandler().addOrderBy(orderBy, order);
return this;
}
@Override
public AskBuilder addOrderBy(Object orderBy, Order order) {
getSolutionModifierHandler().addOrderBy(Converters.makeVar(orderBy), order);
return this;
}
@Override
public AskBuilder addGroupBy(Object groupBy) {
getSolutionModifierHandler().addGroupBy(Converters.makeVar(groupBy));
return this;
}
@Override
public AskBuilder addGroupBy(Expr groupBy) {
getSolutionModifierHandler().addGroupBy(groupBy);
return this;
}
@Override
public AskBuilder addGroupBy(Object var, Expr expr) {
getSolutionModifierHandler().addGroupBy(Converters.makeVar(var), expr);
return this;
}
@Override
public AskBuilder addGroupBy(Object var, String expr) {
getSolutionModifierHandler().addGroupBy(Converters.makeVar(var), makeExpr(expr));
return this;
}
@Override
public AskBuilder addHaving(String having) {
getSolutionModifierHandler().addHaving(having);
return this;
}
@Override
public AskBuilder addHaving(Expr expression) {
getSolutionModifierHandler().addHaving(expression);
return this;
}
@Override
public AskBuilder addHaving(Object var) {
getSolutionModifierHandler().addHaving(Converters.makeVar(var));
return this;
}
@Override
public AskBuilder setLimit(int limit) {
getSolutionModifierHandler().setLimit(limit);
return this;
}
@Override
public AskBuilder setOffset(int offset) {
getSolutionModifierHandler().setOffset(offset);
return this;
}
@Override
public SolutionModifierHandler getSolutionModifierHandler() {
return handlerBlock.getModifierHandler();
}
/*
* @deprecated use {@code addWhere(Converters.makeCollection(List.of(Object...)))}, or simply call {@link #addWhere(Object, Object, Object)} passing the collection for one of the objects.
*/
@Deprecated(since="5.0.0")
@Override
public Node list(Object... objs) {
return getWhereHandler().list(objs);
}
@Override
public AskBuilder addMinus(AbstractQueryBuilder<?> t) {
getWhereHandler().addMinus(t);
return this;
}
}