/*
* #%L
* JSQLParser library
* %%
* Copyright (C) 2004 - 2013 JSQLParser
* %%
* This program 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 program 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 General Lesser Public License for more details.
*
* You should have received a copy of the GNU General Lesser Public
* License along with this program. If not, see
* <http://www.gnu.org/licenses/lgpl-2.1.html>.
* #L%
*/
package net.sf.jsqlparser.statement.select;
import net.sf.jsqlparser.expression.Expression;
/**
* An element (column reference) in an "ORDER BY" clause.
*/
public class OrderByElement {
public enum NullOrdering {
NULLS_FIRST,
NULLS_LAST
}
private Expression expression;
private boolean asc = true;
private NullOrdering nullOrdering;
private boolean ascDesc = false;
public boolean isAsc() {
return asc;
}
public NullOrdering getNullOrdering() {
return nullOrdering;
}
public void setNullOrdering(NullOrdering nullOrdering) {
this.nullOrdering = nullOrdering;
}
public void setAsc(boolean b) {
asc = b;
}
public void setAscDescPresent(boolean b) {
ascDesc = b;
}
public boolean isAscDescPresent() {
return ascDesc;
}
public void accept(OrderByVisitor orderByVisitor) {
orderByVisitor.visit(this);
}
public Expression getExpression() {
return expression;
}
public void setExpression(Expression expression) {
this.expression = expression;
}
@Override
public String toString() {
StringBuilder b = new StringBuilder();
b.append(expression.toString());
if (!asc) {
b.append(" DESC");
} else if (ascDesc) {
b.append(" ASC");
}
if (nullOrdering != null) {
b.append(' ');
b.append(nullOrdering == NullOrdering.NULLS_FIRST ? "NULLS FIRST" : "NULLS LAST");
}
return b.toString();
}
}