/******************************************************************************* * Copyright (c) 2000, 2007 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 * *******************************************************************************/ package org.eclipse.dltk.internal.ui.wizards.buildpath; import java.util.Arrays; import java.util.List; import org.eclipse.core.resources.IContainer; import org.eclipse.core.resources.IFile; import org.eclipse.core.resources.IProject; import org.eclipse.core.resources.IResource; import org.eclipse.core.runtime.CoreException; import org.eclipse.core.runtime.IPath; import org.eclipse.dltk.ui.DLTKUIPlugin; import org.eclipse.jface.viewers.Viewer; import org.eclipse.jface.viewers.ViewerFilter; /** * Viewer filter for archive selection dialogs. Archives are files with file extension 'zip'. The filter is not case sensitive. */ public class ArchiveFileFilter extends ViewerFilter { public static final String[] FILTER_EXTENSIONS = new String [] { "*.zip" }; //$NON-NLS-1$ private static final String[] fgArchiveExtensions = { "zip" }; //$NON-NLS-1$ private List fExcludes; private boolean fRecursive; /** * @param excludedFiles * Excluded files will not pass the filter. <code>null</code> is allowed if no files should be excluded. * @param recusive * Folders are only shown if, searched recursively, contain an archive */ public ArchiveFileFilter( IFile[] excludedFiles, boolean recusive ) { if( excludedFiles != null ) { fExcludes = Arrays.asList( excludedFiles ); } else { fExcludes = null; } fRecursive = recusive; } public ArchiveFileFilter( List excludedFiles, boolean recusive ) { fExcludes = excludedFiles; fRecursive = recusive; } /* * @see ViewerFilter#select */ public boolean select( Viewer viewer, Object parent, Object element ) { if( element instanceof IFile ) { if( fExcludes != null && fExcludes.contains( element ) ) { return false; } return isArchivePath( ( ( IFile )element ).getFullPath( ) ); } else if( element instanceof IContainer ) { // IProject, IFolder if( !fRecursive ) { return true; } // Ignore closed projects if( element instanceof IProject && ! ( ( IProject )element ).isOpen( ) ) return false; try { IResource[] resources = ( ( IContainer )element ).members( ); for( int i = 0; i < resources.length; i++ ) { // recursive! Only show containers that contain an archive if( select( viewer, parent, resources[ i ] ) ) { return true; } } } catch( CoreException e ) { DLTKUIPlugin.log( e.getStatus( ) ); } } return false; } public static boolean isArchivePath( IPath path ) { String ext = path.getFileExtension( ); if( ext != null && ext.length( ) != 0 ) { return isArchiveFileExtension( ext ); } return false; } public static boolean isArchiveFileExtension( String ext ) { for( int i = 0; i < fgArchiveExtensions.length; i++ ) { if( ext.equalsIgnoreCase( fgArchiveExtensions[ i ] ) ) { return true; } } return false; } }