Skip to content

Commit

Permalink
Fixed reverse sort not working
Browse files Browse the repository at this point in the history
  • Loading branch information
sbosley committed Sep 13, 2012
1 parent a7986cd commit e2385f9
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 5 deletions.
24 changes: 23 additions & 1 deletion api/src/com/todoroo/andlib/sql/Order.java
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,12 @@

import static com.todoroo.andlib.sql.SqlConstants.SPACE;

import java.util.ArrayList;
import java.util.List;

public class Order {
private final Object expression;
private final List<Order> secondaryExpressions;
private final OrderType orderType;

private Order(Object expression) {
Expand All @@ -18,6 +22,7 @@ private Order(Object expression) {
private Order(Object expression, OrderType orderType) {
this.expression = expression;
this.orderType = orderType;
this.secondaryExpressions = new ArrayList<Order>();
}

public static Order asc(Object expression) {
Expand All @@ -28,9 +33,26 @@ public static Order desc(Object expression) {
return new Order(expression, OrderType.DESC);
}

public void addSecondaryExpression(Order secondary) {
secondaryExpressions.add(secondary);
}

public void removeSecondaryExpression(Order secondary) {
secondaryExpressions.remove(secondary);
}

@Override
public String toString() {
return expression + SPACE + orderType;
StringBuilder sb = new StringBuilder();
sb.append(expression.toString())
.append(SPACE)
.append(orderType.toString());

for (Order secondary : secondaryExpressions) {
sb.append(", ").append(secondary.toString()); //$NON-NLS-1$
}

return sb.toString();
}

public Order reverse() {
Expand Down
11 changes: 7 additions & 4 deletions api/src/com/todoroo/astrid/core/SortHelper.java
Original file line number Diff line number Diff line change
Expand Up @@ -93,20 +93,23 @@ public static Order orderForSortType(int sortType) {
case SORT_DUE:
order = Order.asc(Functions.caseStatement(Task.DUE_DATE.eq(0),
Functions.now() + "*2", adjustedDueDateFunction()) + "+" + Task.IMPORTANCE +
"+3*" + Task.COMPLETION_DATE + ", " + Task.TITLE);
"+3*" + Task.COMPLETION_DATE);
break;
case SORT_IMPORTANCE:
order = Order.asc(Task.IMPORTANCE + "*" + (2*DateUtilities.now()) + //$NON-NLS-1$
"+" + Functions.caseStatement(Task.DUE_DATE.eq(0), //$NON-NLS-1$
2 * DateUtilities.now(),
Task.DUE_DATE) + "+8*" + Task.COMPLETION_DATE + ", " + Task.TITLE);
Task.DUE_DATE) + "+8*" + Task.COMPLETION_DATE);
break;
case SORT_MODIFIED:
order = Order.desc(Task.MODIFICATION_DATE + ", " + Task.TITLE);
order = Order.desc(Task.MODIFICATION_DATE);
break;
default:
order = defaultTaskOrder();
}
if (sortType != SORT_ALPHA)
order.addSecondaryExpression(Order.asc(Task.TITLE));

return order;
}

Expand All @@ -119,7 +122,7 @@ public static Order defaultTaskOrder() {
return Order.asc(Functions.caseStatement(Task.DUE_DATE.eq(0),
Functions.now() + "*2",
adjustedDueDateFunction()) + " + " + (2 * DateUtilities.ONE_DAY) + " * " +
Task.IMPORTANCE + " + 2*" + Task.COMPLETION_DATE + ", " + Task.TITLE);
Task.IMPORTANCE + " + 2*" + Task.COMPLETION_DATE);
}

@SuppressWarnings("nls")
Expand Down

0 comments on commit e2385f9

Please sign in to comment.