Android Open Source - EverToDo Sort






From Project

Back to project page EverToDo.

License

The source code is released under:

GNU General Public License

If you think the Android project EverToDo listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.

Java Source Code

/**
 *//w ww. j  a  va  2s. c  o  m
 * Todo.txt Touch/src/com/todotxt/todotxttouch/task/Sort.java
 *
 * Copyright (c) 2011 Tim Barlotta
 *
 * LICENSE:
 *
 * This file is part of Todo.txt Touch, an Android app for managing your todo.txt file (http://todotxt.com).
 *
 * Todo.txt Touch is free software: you can redistribute it and/or modify it under the terms of the GNU General Public
 * License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any
 * later version.
 *
 * Todo.txt Touch 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 Public License for more
 * details.
 *
 * You should have received a copy of the GNU General Public License along with Todo.txt Touch.  If not, see
 * <http://www.gnu.org/licenses/>.
 * 
 * Sort
 * Holds Task Sorting options and their associated comparators
 *
 * @author Tim Barlotta <tim[at]barlotta[dot]net>
 * @license http://www.gnu.org/licenses/gpl.html
 * @copyright 2011 Tim Barlotta
 */
package com.todotxt.todotxttouch.task;

import java.util.Comparator;

public enum Sort {
  /**
   * Priority descending sort should result in Tasks in the following order
   * <p>
   * (A), (B), (C), ..., (Z), (NO PRIORITY), (COMPLETED)
   * </p>
   * <p>
   * If tasks are of the same priority level, they are sorted by task id
   * ascending
   * </p>
   * <p>
   * Note: this comparator imposes orderings that are inconsistent with
   * equals.
   * </p>
   */
  PRIORITY_DESC(0, new Comparator<Task>() {
    @Override
    public int compare(Task t1, Task t2) {
      if (t1 == null || t2 == null) {
        throw new NullPointerException(
            "Null task passed into comparator");
      }

      if (t1.isCompleted() && t2.isCompleted()) {
        return Sort.ID_ASC.getComparator().compare(t1, t2);
      }

      if (t1.isCompleted() || t2.isCompleted()) {
        if (t1.isCompleted()) {
          return 1;
        } else {
          return -1;
        }
      }

      if (t1.getPriority() == Priority.NONE
          && t2.getPriority() == Priority.NONE) {
        return Sort.ID_ASC.getComparator().compare(t1, t2);
      }

      if (t1.getPriority() == Priority.NONE
          || t2.getPriority() == Priority.NONE) {
        if (t1.getPriority() == Priority.NONE) {
          return 1;
        } else {
          return -1;
        }
      }

      int result = t1.getPriority().compareTo(t2.getPriority());
      if (result == 0) {
        result = Sort.ID_ASC.getComparator().compare(t1, t2);
      }
      return result;
    }
  }),

  /**
   * Id ascending sort should result in Tasks in the following order
   * <p>
   * 1, 2, 3, 4, ..., n
   * </p>
   * <p>
   * Note: this comparator imposes orderings that are inconsistent with
   * equals.
   * </p>
   */
  ID_ASC(1, new Comparator<Task>() {
    @Override
    public int compare(Task t1, Task t2) {
      if (t1 == null || t2 == null) {
        throw new NullPointerException(
            "Null task passed into comparator");
      }

      return Long.valueOf(t1.getId()).compareTo(t2.getId());
    }
  }),

  /**
   * Id ascending sort should result in Tasks in the following order
   * <p>
   * n, ..., 4, 3, 2, 1
   * </p>
   * <p>
   * Note: this comparator imposes orderings that are inconsistent with
   * equals.
   * </p>
   */
  ID_DESC(2, new Comparator<Task>() {
    @Override
    public int compare(Task t1, Task t2) {
      if (t1 == null || t2 == null) {
        throw new NullPointerException(
            "Null task passed into comparator");
      }

      return Long.valueOf(t2.getId()).compareTo(t1.getId());
    }
  }),

  /**
   * Text ascending sort should result in Tasks sorting in the following order
   * <p>
   * a, b, c, d, e, ..., z
   * </p>
   * <p>
   * If tasks are of the same priority level, they are sorted by task id
   * ascending
   * </p>
   * <p>
   * Note: this comparator imposes orderings that are inconsistent with
   * equals.
   * </p>
   */
  TEXT_ASC(3, new Comparator<Task>() {
    @Override
    public int compare(Task t1, Task t2) {
      if (t1 == null || t2 == null) {
        throw new NullPointerException(
            "Null task passed into comparator");
      }

      int result = t1.getText().compareToIgnoreCase(t2.getText());
      if (result == 0) {
        result = Sort.ID_ASC.getComparator().compare(t1, t2);
      }
      return result;
    }
  });

  private final int id;
  private final Comparator<Task> comparator;

  private Sort(int id, Comparator<Task> comparator) {
    this.id = id;
    this.comparator = comparator;
  }

  public int getId() {
    return id;
  }

  public Comparator<Task> getComparator() {
    return comparator;
  }

  /**
   * Retrieves the sort selection by its id, default to PRIORITY_DESC if no
   * matching sort is found
   * 
   * @param id
   *            the sort id to lookup
   * @return the matching sort or PRIORITY_DESC if no match is found
   */
  public static Sort getById(int id) {
    for (Sort sort : Sort.values()) {
      if (sort.id == id) {
        return sort;
      }
    }
    return Sort.PRIORITY_DESC;
  }

}




Java Source Code List

com.todotxt.todotxttouch.AddTask.java
com.todotxt.todotxttouch.Constants.java
com.todotxt.todotxttouch.Filter.java
com.todotxt.todotxttouch.HelpActivity.java
com.todotxt.todotxttouch.LoginScreen.java
com.todotxt.todotxttouch.Preferences.java
com.todotxt.todotxttouch.TodoApplication.java
com.todotxt.todotxttouch.TodoException.java
com.todotxt.todotxttouch.TodoTxtTouch.java
com.todotxt.todotxttouch.remote.Client.java
com.todotxt.todotxttouch.remote.DropboxFileRemoteException.java
com.todotxt.todotxttouch.remote.DropboxLoginAsyncTask.java
com.todotxt.todotxttouch.remote.DropboxRemoteClient.java
com.todotxt.todotxttouch.remote.LocalClient.java
com.todotxt.todotxttouch.remote.RemoteClientManager.java
com.todotxt.todotxttouch.remote.RemoteClient.java
com.todotxt.todotxttouch.remote.RemoteException.java
com.todotxt.todotxttouch.remote.RemoteLoginTask.java
com.todotxt.todotxttouch.task.AndFilter.java
com.todotxt.todotxttouch.task.ByContextFilter.java
com.todotxt.todotxttouch.task.ByPriorityFilter.java
com.todotxt.todotxttouch.task.ByProjectFilter.java
com.todotxt.todotxttouch.task.ByTextFilter.java
com.todotxt.todotxttouch.task.ContextParser.java
com.todotxt.todotxttouch.task.FilterFactory.java
com.todotxt.todotxttouch.task.Filter.java
com.todotxt.todotxttouch.task.LocalFileTaskRepository.java
com.todotxt.todotxttouch.task.LocalTaskRepository.java
com.todotxt.todotxttouch.task.OrFilter.java
com.todotxt.todotxttouch.task.PriorityTextSplitter.java
com.todotxt.todotxttouch.task.Priority.java
com.todotxt.todotxttouch.task.ProjectParser.java
com.todotxt.todotxttouch.task.Sort.java
com.todotxt.todotxttouch.task.TaskBagFactory.java
com.todotxt.todotxttouch.task.TaskBagImpl.java
com.todotxt.todotxttouch.task.TaskBag.java
com.todotxt.todotxttouch.task.TaskPersistException.java
com.todotxt.todotxttouch.task.Task.java
com.todotxt.todotxttouch.task.TextSplitter.java
com.todotxt.todotxttouch.util.CursorPositionCalculator.java
com.todotxt.todotxttouch.util.RelativeDate.java
com.todotxt.todotxttouch.util.Strings.java
com.todotxt.todotxttouch.util.TaskIo.java
com.todotxt.todotxttouch.util.Util.java