/*******************************************************************************
* Copyright (c) 2009 Johannes Utzig.
* 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:
* Johannes Utzig - initial API and implementation
*******************************************************************************/
package org.eclipse.buckminster.ui.dependency.visualizer.viewer.provider;
import java.util.Collection;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import org.eclipse.buckminster.core.metadata.model.BOMNode;
import org.eclipse.jface.viewers.Viewer;
import org.eclipse.zest.core.viewers.IGraphEntityContentProvider;
/**
* retrieves all components of a given {@link BOMNode}
*
* @author Johannes Utzig
*
*/
public class DependencyContentProvider implements IGraphEntityContentProvider {
@Override
public void dispose() {
// nothing to dispose
}
@Override
public Object[] getConnectedTo(Object entity) {
if (entity instanceof BOMNode) {
BOMNode node = (BOMNode) entity;
return node.getChildren().toArray();
}
return null;
}
@Override
@SuppressWarnings("unchecked")
public Object[] getElements(Object inputElement) {
if (inputElement instanceof List<?>) {
List<BOMNode> input = (List<BOMNode>) inputElement;
Set<BOMNode> nodes = new HashSet<BOMNode>();
for (BOMNode bomNode : input) {
nodes.add(bomNode);
getElementsRecursivly(bomNode, nodes);
}
return nodes.toArray();
}
return null;
}
@Override
public void inputChanged(Viewer viewer, Object oldInput, Object newInput) {
// nothing to do
}
private Set<BOMNode> getElementsRecursivly(BOMNode node, Set<BOMNode> allElements) {
Collection<BOMNode> children = node.getChildren();
for (BOMNode bomNode : children) {
allElements.add(bomNode);
getElementsRecursivly(bomNode, allElements);
}
allElements.addAll(children);
return allElements;
}
}