/* * Copyright (c) 1998-2011 Caucho Technology -- all rights reserved * * This file is part of Resin(R) Open Source * * Each copy or derived work must preserve the copyright notice and this * notice unmodified. * * Resin Open Source is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * Resin Open Source is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty * of NON-INFRINGEMENT. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License * along with Resin Open Source; if not, write to the * * Free Software Foundation, Inc. * 59 Temple Place, Suite 330 * Boston, MA 02111-1307 USA * * @author Scott Ferguson */ package com.caucho.el; import com.caucho.vfs.WriteStream; import javax.el.ELContext; import javax.el.ELException; import java.io.IOException; import java.math.BigDecimal; import java.math.BigInteger; /** * Represents the numeric comparison operation: le */ public class GeExpr extends AbstractBooleanExpr { private final Expr _left; private final Expr _right; /** * Creates a comparison expression * * @param op the lexical code for the operation * @param left the left subexpression * @param right the right subexpression */ public GeExpr(Expr left, Expr right) { _left = left; _right = right; } /** * Returns true if this is a constant expression. */ @Override public boolean isConstant() { return _left.isConstant() && _right.isConstant(); } /** * Evaluate the expression as a boolean. * * @param env the variable environment */ @Override public boolean evalBoolean(ELContext env) throws ELException { Object aObj = _left.getValue(env); Object bObj = _right.getValue(env); if (aObj == bObj) return true; if (aObj == null || bObj == null) return false; Class aType = aObj.getClass(); Class bType = bObj.getClass(); if (aObj instanceof BigDecimal || bObj instanceof BigDecimal) { BigDecimal a = toBigDecimal(aObj, env); BigDecimal b = toBigDecimal(bObj, env); return a.compareTo(b) >= 0; } if (aType == Double.class || aType == Float.class || bType == Double.class || bType == Float.class) { double a = toDouble(aObj, env); double b = toDouble(bObj, env); return a >= b; } if (aType == BigInteger.class || bType == BigInteger.class) { BigInteger a = toBigInteger(aObj, env); BigInteger b = toBigInteger(bObj, env); return a.compareTo(b) >= 0; } if (aObj instanceof Number || bObj instanceof Number) { long a = toLong(aObj, env); long b = toLong(bObj, env); return a >= b; } if (aObj instanceof String || bObj instanceof String) { String a = toString(aObj, env); String b = toString(bObj, env); return a.compareTo(b) >= 0; } if (aObj instanceof Comparable) { int cmp = ((Comparable) aObj).compareTo(bObj); return cmp >= 0; } if (bObj instanceof Comparable) { int cmp = ((Comparable) bObj).compareTo(aObj); return cmp <= 0; } ELException e = new ELException(L.l("can't compare {0} and {1}.", aObj, bObj)); error(e, env); return false; } /** * Prints the code to create an LongLiteral. */ @Override public void printCreate(WriteStream os) throws IOException { os.print("new com.caucho.el.GeExpr("); _left.printCreate(os); os.print(", "); _right.printCreate(os); os.print(")"); } /** * Returns true for equal strings. */ public boolean equals(Object o) { if (! (o instanceof GeExpr)) return false; GeExpr expr = (GeExpr) o; return (_left.equals(expr._left) && _right.equals(expr._right)); } /** * Returns a readable representation of the expr. */ public String toString() { return "(" + _left + " le " + _right + ")"; } }