blob: 4982d246731bb563004d4589c7dc468463dfd60f [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 2017 IBM Corporation and others.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* SPDX-License-Identifier: EPL-2.0
*
*******************************************************************************/
package org.eclipse.dltk.internal.ui.wizards;
import org.eclipse.core.runtime.Assert;
import org.eclipse.jface.viewers.Viewer;
import org.eclipse.jface.viewers.ViewerFilter;
/**
* Viewer filter used in selection dialogs.
*/
public class TypedViewerFilter extends ViewerFilter {
private Class<?>[] fAcceptedTypes;
private Object[] fRejectedElements;
/**
* Creates a filter that only allows elements of gives types.
* @param acceptedTypes The types of accepted elements
*/
public TypedViewerFilter(Class<?>[] acceptedTypes) {
this(acceptedTypes, null);
}
/**
* Creates a filter that only allows elements of gives types, but not from a
* list of rejected elements.
* @param acceptedTypes Accepted elements must be of this types
* @param rejectedElements Element equals to the rejected elements are
* filtered out
*/
public TypedViewerFilter(Class<?>[] acceptedTypes, Object[] rejectedElements) {
Assert.isNotNull(acceptedTypes);
fAcceptedTypes= acceptedTypes;
fRejectedElements= rejectedElements;
}
@Override
public boolean select(Viewer viewer, Object parentElement, Object element) {
if (fRejectedElements != null) {
for (int i= 0; i < fRejectedElements.length; i++) {
if (element.equals(fRejectedElements[i])) {
return false;
}
}
}
for (int i= 0; i < fAcceptedTypes.length; i++) {
if (fAcceptedTypes[i].isInstance(element)) {
return true;
}
}
return false;
}
}