Skip to main content
aboutsummaryrefslogblamecommitdiffstats
blob: d15212989095f8f4dd9939852841afe9c81e5139 (plain) (tree)
1
2
3
4
5
6
7
8
9






                                                                                 
                                                      
                                                                                 
                              
 
                                       



                                                  
                                           


                                                                         
                                    



                       
                                                                          

                                                        
                                         
                                     







                                                  
                              


































































                                                                                                                                           
/*******************************************************************************
 * 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);
}

Back to the top