/******************************************************************************* * Copyright (c) 2006-2015 * Software Technology Group, Dresden University of Technology * DevBoost GmbH, Dresden, Amtsgericht Dresden, HRB 34001 * * 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: * Software Technology Group - TU Dresden, Germany; * DevBoost GmbH - Dresden, Germany * - initial API and implementation ******************************************************************************/ package de.devboost.buildboost.discovery; import java.io.File; import java.io.FileFilter; import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import de.devboost.buildboost.artifacts.EclipseFeature; import de.devboost.buildboost.model.IArtifact; import de.devboost.buildboost.model.IBuildContext; import de.devboost.buildboost.util.ArtifactUtil; /** * An {@link EclipseFeatureFinder} can be used to discover Eclipse features (i.e., files with name 'feature.xml'). In * contrast to the {@link EclipseTargetPlatformAnalyzer} which does also discover Eclipse features, this class is only * used to search for features in projects (i.e., it does not consider packaged features in JAR files). * * TODO inherit from {@link AbstractFileFinder}? */ public class EclipseFeatureFinder extends AbstractArtifactDiscoverer { private final File directory; public EclipseFeatureFinder(File directory) { super(); this.directory = directory; } public Collection<IArtifact> discoverArtifacts(IBuildContext context) { Collection<EclipseFeature> features = discoverArtifacts(context, directory); return new ArtifactUtil().getSetOfArtifacts(features); } private Collection<EclipseFeature> discoverArtifacts(IBuildContext context, File directory) { Collection<EclipseFeature> features = new ArrayList<EclipseFeature>(); features.addAll(findFeatureFiles(directory)); traverseSubDirectories(context, directory, features); return features; } private void traverseSubDirectories(IBuildContext context, File directory, Collection<EclipseFeature> features) { File[] subDirectories = directory.listFiles(new FileFilter() { public boolean accept(File file) { return file.isDirectory(); } }); if (subDirectories == null) { return; } for (File subDirectory : subDirectories) { features.addAll(discoverArtifacts(context, subDirectory)); } } private Collection<EclipseFeature> findFeatureFiles(File directory) { File[] featureXmlFiles = directory.listFiles(new FileFilter() { public boolean accept(File file) { return file.getName().equals("feature.xml"); } }); if (featureXmlFiles == null) { return Collections.emptySet(); } Collection<EclipseFeature> features = new ArrayList<EclipseFeature>(featureXmlFiles.length); for (File featureXmlFile : featureXmlFiles) { features.add(new EclipseFeature(featureXmlFile, false)); } return features; } @Override public String toString() { return getClass().getSimpleName() + " [" + directory + "]"; } }