org.eclipse.tm.te.ui.AbstractViewerComparator.java Source code

Java tutorial

Introduction

Here is the source code for org.eclipse.tm.te.ui.AbstractViewerComparator.java

Source

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