/*******************************************************************************
* Copyright (c) 2011 Wind River Systems, Inc. and others. All rights reserved.
* This program and the accompanying materials are made available under the terms
* of the Eclipse Public License v1.0 which accompanies this distribution, and is
* available at http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Wind River Systems - initial API and implementation
*******************************************************************************/
package org.eclipse.tcf.te.ui;
import org.eclipse.core.runtime.Assert;
import org.eclipse.jface.viewers.Viewer;
import org.eclipse.jface.viewers.ViewerComparator;
/**
* Common viewer comparator implementation.
*/
public abstract class AbstractViewerComparator extends ViewerComparator {
// Reference to the viewer
private final Viewer viewer;
/**
* Constructor.
*
* @param viewer The parent viewer. Must not be <code>null</code>.
*/
public AbstractViewerComparator(Viewer viewer) {
Assert.isNotNull(viewer);
this.viewer = viewer;
}
/**
* Returns the parent viewer instance.
*
* @return The parent viewer instance.
*/
protected final Viewer getParentViewer() {
return viewer;
}
/* (non-Javadoc)
* @see org.eclipse.jface.viewers.ViewerComparator#compare(org.eclipse.jface.viewers.Viewer, java.lang.Object, java.lang.Object)
*/
@Override
public int compare(Viewer viewer, Object e1, Object e2) {
if (viewer != null && viewer.getControl() != null && !viewer.getControl().isDisposed()) {
return doCompare(e1, e2, doGetSortColumnLabel(viewer), doGetSortColumnIndex(viewer) , doDetermineInverter(viewer));
}
return super.compare(viewer, e1, e2);
}
/* (non-Javadoc)
* @see java.util.Comparator#compare(java.lang.Object, java.lang.Object)
*/
public int compare(Object o1, Object o2) {
return doCompare(o1, o2, null, -1, doDetermineInverter(getParentViewer()));
}
/**
* Compare the given nodes by the given sort column and inverter.
*
* @param node1 The first node or <code>null</code>.
* @param node2 The second node or <code>null</code>.
* @param sortColumn The sort column text or <code>null</code>.
* @param index The sort column index or <code>-1</code>.
* @param inverter The inverter.
*
* @return The compare result.
*/
protected abstract int doCompare(Object node1, Object node2, String sortColumn, int index, int inverter);
/**
* Returns the text to compare for the given node and column index.
*
* @param node The node or <code>null</code>.
* @param index The column index or <code>-1</code>.
*
* @return The text for the given node and column index or <code>null</code>.
*/
protected abstract String doGetText(Object node, int index);
/**
* Determine if or if not the sort direction needs to be inverted.
*
* @param viewer The viewer or <code>null</code>.
* @return <code>1</code> for original sort order, or <code>-1</code> for inverted sort order.
*/
protected abstract int doDetermineInverter(Viewer viewer);
/**
* Return the label of the sort column of the given viewer.
*
* @param viewer The viewer or <code>null</code>.
* @return The label of the sort column or an empty string.
*/
protected abstract String doGetSortColumnLabel(Viewer viewer);
/**
* Return the index of the sort column of the given viewer.
*
* @param viewer The viewer or <code>null</code>.
* @return The index of the sort column or <code>-1</code>.
*/
protected abstract int doGetSortColumnIndex(Viewer viewer);
}