/************************************************************************************** * Copyright (C) 2008 EsperTech, Inc. All rights reserved. * * http://esper.codehaus.org * * http://www.espertech.com * * ---------------------------------------------------------------------------------- * * The software in this package is published under the terms of the GPL license * * a copy of which has been included with this distribution in the license.txt file. * **************************************************************************************/ package com.espertech.esper.client.soda; import java.io.StringWriter; /** * Minimum of the (distinct) values returned by an expression. */ public class MinProjectionExpression extends ExpressionBase { private boolean distinct; private static final long serialVersionUID = -5521787388585609418L; /** * Ctor. */ public MinProjectionExpression() { } /** * Ctor - for use to create an expression tree, without inner expression * @param isDistinct true if distinct */ public MinProjectionExpression(boolean isDistinct) { this.distinct = isDistinct; } /** * Ctor - adds the expression to project. * @param expression returning values to project * @param isDistinct true if distinct */ public MinProjectionExpression(Expression expression, boolean isDistinct) { this.distinct = isDistinct; this.getChildren().add(expression); } public ExpressionPrecedenceEnum getPrecedence() { return ExpressionPrecedenceEnum.UNARY; } public void toPrecedenceFreeEPL(StringWriter writer) { if (this.getChildren().size() > 1) { writer.write("fmin("); } else { writer.write("min("); } if (distinct) { writer.write("distinct "); } String delimiter = ""; for (Expression param : this.getChildren()) { writer.write(delimiter); delimiter = ", "; param.toEPL(writer, ExpressionPrecedenceEnum.MINIMUM); } writer.write(")"); } /** * Returns true if the projection considers distinct values only. * @return true if distinct */ public boolean isDistinct() { return distinct; } /** * Returns true if the projection considers distinct values only. * @return true if distinct */ public boolean getDistinct() { return distinct; } /** * Set the distinct flag indicating the projection considers distinct values only. * @param distinct true for distinct, false for not distinct */ public void setDistinct(boolean distinct) { this.distinct = distinct; } }