/**
* Copyright (C) 2012 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package co.jirm.orm.builder.select;
public class OrderByClauseBuilder<I> extends AbstractSqlParameterizedSelectClause<OrderByClauseBuilder<I>, I>
implements OrderByPartial<OrderByClauseBuilder<I>> {
private ImmutableOrderByPartial orderByPartial;
private OrderByClauseBuilder(SelectClause<I> parent, String sql) {
super(parent, SelectClauseType.ORDERBY, sql);
}
public static <I> OrderByClauseBuilder<I> newInstanceForCustom(SelectClause<I> parent, String sql) {
OrderByClauseBuilder<I> b = new OrderByClauseBuilder<I>(parent, sql);
return b;
}
public static <I> OrderByClauseBuilder<I> newInstanceForProperty(SelectClause<I> parent, String sql) {
OrderByClauseBuilder<I> b = new OrderByClauseBuilder<I>(parent, "");
b.orderByPartial = ImmutableOrderByPartial.newInstance("{{" + sql + "}}");
return b;
}
public static <I> OrderByClauseBuilder<I> newInstanceForField(SelectClause<I> parent, String sql) {
OrderByClauseBuilder<I> b = new OrderByClauseBuilder<I>(parent, "");
b.orderByPartial = ImmutableOrderByPartial.newInstance(sql);
return b;
}
@Override
public boolean isNoOp() {
return super.isNoOp() && orderByPartial == null;
}
@Override
protected OrderByClauseBuilder<I> getSelf() {
return this;
}
@Override
public <C extends SelectClauseVisitor> C accept(C visitor) {
visitor.visit(this);
for (SelectClause<I> k : children) {
k.accept(visitor);
}
return visitor;
}
public LimitClauseBuilder<I> limit(String sql) {
return addClause(LimitClauseBuilder.newInstance(this, sql));
}
public LimitClauseBuilder<I> limit(Number i) {
return addClause(LimitClauseBuilder.newInstanceWithLimit(this, i));
}
public OffsetClauseBuilder<I> offset(String sql) {
return addClause(OffsetClauseBuilder.newInstance(getSelf(), sql));
}
public OffsetClauseBuilder<I> offset(Number i) {
return addClause(OffsetClauseBuilder.newInstanceWithOffset(getSelf(), i));
}
public ForUpdateClauseBuilder<I> forUpdate() {
return addClause(ForUpdateClauseBuilder.newInstance(this));
}
public ForShareClauseBuilder<I> forShare() {
return addClause(ForShareClauseBuilder.newInstance(this));
}
//@Override
public OrderByClauseBuilder<I> asc() {
this.orderByPartial = this.orderByPartial.asc();
return getSelf();
}
@Override
public OrderByClauseBuilder<I> desc() {
this.orderByPartial = this.orderByPartial.desc();
return getSelf();
}
public OrderByClauseBuilder<I> property(String sql) {
this.orderByPartial = this.orderByPartial.orderBy("{{" + sql + "}}");
return getSelf();
}
public OrderByClauseBuilder<I> field(String sql) {
this.orderByPartial = this.orderByPartial.orderBy(sql);
return getSelf();
}
@Override
public OrderByMode getOrderMode() {
return orderByPartial.getOrderMode();
}
public ImmutableOrderByPartial getOrderByPartial() {
return orderByPartial;
}
@Override
public OrderByClauseBuilder<I> orderBy(String sql) {
return property(sql);
}
}