Class TableUpdateJob<T>

java.lang.Object
docking.widgets.table.threaded.TableUpdateJob<T>
Type Parameters:
T - the type of data that each row in the table represents.
Direct Known Subclasses:
AddRemoveJob, FilterJob, LoadJob, LoadSpecificDataJob, SortJob

public class TableUpdateJob<T> extends Object
State machine object for performing the various update functions on a ThreadedTableModel. The general pattern is to:
  1. Load
  2. Filter
  3. Process individual adds and removes
  4. Sort
  5. Set the processed data back on the model

Not all the update functions are performed on a run of a TableUpdateJob. If the reloadData flag is not set, the the data is just copied from the model's current list, instead of calling the model's loadData() method. If the sortComparator is null, then the data is not sorted (for example, when only filtering needs to be done). If there are no add/removes in the list, then that step does nothing.

Before the job completes, new calls to sort and filter can be called. If the job is past the stage of the new call, the monitor is cancelled, causing the current stage to abort. The next state of this job is set to the appropriate state for the call, the monitor is reset, and the job begins executing the next stage, based upon the new call.

  • Field Details

  • Method Details

    • setData

      protected void setData(TableData<T> data)
      Meant to be called by subclasses, not clients. This method will trigger this job not to load data, but rather to use the given data.
      Parameters:
      data - The data to process.
    • setForceFilter

      protected void setForceFilter(boolean force)
      Allows the precise disabling of the filter operation. For example, when the user sorts, no filtering is needed. If the filter has changed, then a filter will take place, regardless of the state of this variable.
      Parameters:
      force - false to reuse the current filter, if possible.
    • run

      public void run()
      The basic run() method that executes the state machine.
    • reload

      public void reload()
      Forces this job to completely reload the data, instead of copying from the model's current data. This call is not allowed on the currently running job and is only appropriate for a pending job.
    • addRemove

      public void addRemove(AddRemoveListItem<T> item, int maxAddRemoveCount)
      Adds the Add/Remove item to the list of items to be processed in the add/remove phase. This call is not allowed on running jobs, only pending jobs.
      Parameters:
      item - the add/remove item to add to the list of items to be processed in the add/remove phase of this job.
      maxAddRemoveCount - the maximum number of add/remove jobs to queue before performing a full reload
    • requestSort

      public boolean requestSort(TableSortingContext<T> newSortingContext, boolean forceSort)
      Sets the TableColumnComparator to use for sorting the data. This method can be called on the currently running job as well as the pending job. If called on the running job, the effect depends on the running job's state:
      • If the sort state hasn't happened yet, all it does is set the comparator for when the sort occurs.
      • If the sort state has already been started or completed, then this method attempts to stop the current process phase and cause the state machine to return to the sort phase.
      • If the current job has already entered the DONE state, then the sort cannot take effect in this job and a false value is returned to indicate the sort was not handled by this job.
      Parameters:
      newSortingContext - the TableColumnComparator to use to sort the data.
      forceSort - True signals to re-sort, even if this is already sorted
      Returns:
      true if the sort can be processed by this job, false if this job is essentially already completed and therefor cannot perform the sort job.
    • requestFilter

      public boolean requestFilter()
      Tells the job that the filter criteria has changed. This method can be called on the currently running job as well as the pending job. If called on the running job, the effect depends on the running job's state:
      • If the filter state hasn't happened yet, then nothing needs to be done as this job will filter later anyway.
      • If the filter state has already been started or completed, then this method attempts to stop the current process phase and cause the state machine to return to the filter phase.
      • If the current job has already entered the DONE state, then the filter cannot take effect in this job and a false value is returned to indicate the filter was not handled by this job.
      Returns:
      true if the filter can be processed by this job, false if this job is essentially already completed and therefor cannot perform the filter job.
    • cancel

      public void cancel()
    • toString

      public String toString()
      Overrides:
      toString in class Object