Package org.openrdf.sail.rdbms.algebra.factories

Source Code of org.openrdf.sail.rdbms.algebra.factories.NumericExprFactory

/*
* 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;
  }

}
TOP

Related Classes of org.openrdf.sail.rdbms.algebra.factories.NumericExprFactory

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.