/**
*
* Copyright (c) 2014, the Railo Company Ltd. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
*
**/
package lucee.transformer.cfml.evaluator.func.impl;
import lucee.runtime.exp.TemplateException;
import lucee.transformer.bytecode.expression.var.Argument;
import lucee.transformer.bytecode.expression.var.BIF;
import lucee.transformer.bytecode.op.OpBigDecimal;
import lucee.transformer.bytecode.op.OpDouble;
import lucee.transformer.cfml.evaluator.EvaluatorException;
import lucee.transformer.cfml.evaluator.FunctionEvaluator;
import lucee.transformer.expression.Expression;
import lucee.transformer.library.function.FunctionLibFunction;
public class PrecisionEvaluate implements FunctionEvaluator {
@Override
public void execute(BIF bif, FunctionLibFunction flf) throws TemplateException {
Argument[] args = bif.getArguments();
for (Argument arg : args) {
Expression value = arg.getValue();
if (value instanceof OpDouble) {
arg.setValue(value.getFactory().toExprString(toOpBigDecimal(((OpDouble)value))), "any");
}
}
}
private OpBigDecimal toOpBigDecimal(OpDouble op) {
Expression left = op.getLeft();
Expression right = op.getRight();
if(left instanceof OpDouble) left=toOpBigDecimal((OpDouble) left);
if(right instanceof OpDouble) right=toOpBigDecimal((OpDouble) right);
return new OpBigDecimal(left, right, op.getOperation());
}
@Override
public void evaluate(BIF bif, FunctionLibFunction flf) throws EvaluatorException {}
@Override
public FunctionLibFunction pre(BIF bif, FunctionLibFunction flf) throws TemplateException {return null;}
}