/*
* Copyright Aduna (http://www.aduna-software.com/) (c) 2008.
*
* Licensed under the Aduna BSD-style license.
*/
package org.openrdf.sail.rdbms.algebra.factories;
import static org.openrdf.sail.rdbms.algebra.base.SqlExprSupport.sqlNull;
import static org.openrdf.sail.rdbms.algebra.base.SqlExprSupport.unsupported;
import org.openrdf.model.Literal;
import org.openrdf.model.URI;
import org.openrdf.model.Value;
import org.openrdf.model.datatypes.XMLDatatypeUtil;
import org.openrdf.query.algebra.Datatype;
import org.openrdf.query.algebra.Lang;
import org.openrdf.query.algebra.MathExpr;
import org.openrdf.query.algebra.QueryModelNode;
import org.openrdf.query.algebra.Str;
import org.openrdf.query.algebra.ValueConstant;
import org.openrdf.query.algebra.ValueExpr;
import org.openrdf.query.algebra.Var;
import org.openrdf.query.algebra.MathExpr.MathOp;
import org.openrdf.query.algebra.helpers.QueryModelVisitorBase;
import org.openrdf.sail.rdbms.algebra.DoubleValue;
import org.openrdf.sail.rdbms.algebra.NumericColumn;
import org.openrdf.sail.rdbms.algebra.SqlMathExpr;
import org.openrdf.sail.rdbms.algebra.SqlNull;
import org.openrdf.sail.rdbms.algebra.base.SqlExpr;
import org.openrdf.sail.rdbms.exceptions.UnsupportedRdbmsOperatorException;
/**
* Creates an SQL expression of a literal's numeric value.
*
* @author James Leigh
*/
public class NumericExprFactory extends QueryModelVisitorBase<UnsupportedRdbmsOperatorException> {
protected SqlExpr result;
public SqlExpr createNumericExpr(ValueExpr expr)
throws UnsupportedRdbmsOperatorException
{
result = null;
if (expr == null) {
return new SqlNull();
}
expr.visit(this);
if (result == null) {
return new SqlNull();
}
return result;
}
@Override
public void meet(Datatype node) {
result = sqlNull();
}
@Override
public void meet(Lang node)
throws UnsupportedRdbmsOperatorException
{
result = sqlNull();
}
@Override
public void meet(MathExpr node)
throws UnsupportedRdbmsOperatorException
{
SqlExpr left = createNumericExpr(node.getLeftArg());
SqlExpr right = createNumericExpr(node.getRightArg());
MathOp op = node.getOperator();
result = new SqlMathExpr(left, op, right);
}
@Override
public void meet(Str node) {
result = sqlNull();
}
@Override
public void meet(ValueConstant vc) {
result = valueOf(vc.getValue());
}
@Override
public void meet(Var var) {
if (var.getValue() == null) {
result = new NumericColumn(var);
}
else {
result = valueOf(var.getValue());
}
}
@Override
protected void meetNode(QueryModelNode arg)
throws UnsupportedRdbmsOperatorException
{
throw unsupported(arg);
}
private SqlExpr valueOf(Value value) {
if (value instanceof Literal) {
Literal lit = (Literal)value;
URI dt = lit.getDatatype();
if (dt != null && XMLDatatypeUtil.isNumericDatatype(dt)) {
try {
return new DoubleValue(lit.doubleValue());
}
catch (NumberFormatException e) {
return null;
}
}
}
return null;
}
}