blob: 66c65df263d6feacc2d695c513d0104826f96ad3 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2004, 2015 IBM Corporation 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:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.ui.internal.dialogs;
import org.eclipse.jface.viewers.AbstractTreeViewer;
import org.eclipse.jface.viewers.ITreeContentProvider;
import org.eclipse.jface.viewers.Viewer;
import org.eclipse.jface.viewers.ViewerFilter;
import org.eclipse.ui.wizards.IWizardDescriptor;
/**
* A viewer filter that will exclude all IWizardDescriptors that do not have at
* least one tag in a provided set.
*
* @since 3.1
*/
public class WizardTagFilter extends ViewerFilter {
private String [] myTags;
/**
* Create a new instance of this filter
* @param tags the wizard tags to allow
*/
public WizardTagFilter(String [] tags) {
myTags = tags;
}
@Override
public boolean select(Viewer viewer, Object parentElement, Object element) {
if (element instanceof IWizardDescriptor) {
IWizardDescriptor desc = (IWizardDescriptor)element;
for (String tag : desc.getTags()) {
for (String myTag : myTags) {
if (tag.equals(myTag)) {
return true;
}
}
}
return false;
}
Object[] children = ((ITreeContentProvider) ((AbstractTreeViewer) viewer)
.getContentProvider()).getChildren(element);
if (children.length > 0) {
return filter(viewer, element, children).length > 0;
}
return false;
}
}