blob: ab0254290186ff39b4dbcffce0bc9d8ba6cf62af [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2003, 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
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.debug.core.sourcelookup.containers;
import java.util.ArrayList;
import java.util.List;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.MultiStatus;
import org.eclipse.debug.core.DebugPlugin;
import org.eclipse.debug.core.sourcelookup.ISourceContainer;
import org.eclipse.debug.internal.core.sourcelookup.SourceLookupMessages;
/**
* A source container of source containers.
* <p>
* Clients implementing composite source containers should subclass
* this class.
* </p>
* @since 3.0
*/
public abstract class CompositeSourceContainer extends AbstractSourceContainer {
private ISourceContainer[] fContainers;
/* (non-Javadoc)
* @see org.eclipse.debug.core.sourcelookup.ISourceContainer#isComposite()
*/
public boolean isComposite() {
return true;
}
/* (non-Javadoc)
* @see org.eclipse.debug.core.sourcelookup.ISourceContainer#findSourceElements(java.lang.String)
*/
public Object[] findSourceElements(String name) throws CoreException {
return findSourceElements(name, getSourceContainers());
}
/**
* Returns a collection of source elements in the given containers corresponding to
* the given name. Returns an empty collection if no source elements are found.
* This source container's source lookup director specifies if duplicate
* source elements should be searched for, via <code>isFindDuplicates()</code>.
* When <code>false</code> the returned collection should contain at most one
* source element. If this is a composite container, the containers contained
* by this container are also searched.
* <p>
* The format of the given name is implementation specific but generally conforms
* to the format of a file name. If a source container does not recognize the
* name format provided, an empty collection should be returned. A source container
* may or may not require names to be fully qualified (i.e. be qualified with directory
* names).
* </p>
* @param name the name of the source element to search for
* @param containers the containers to search
* @return a collection of source elements corresponding to the given name
* @exception CoreException if an exception occurs while searching for source elements
*/
protected Object[] findSourceElements(String name, ISourceContainer[] containers) throws CoreException {
List results = null;
CoreException single = null;
MultiStatus multiStatus = null;
if (isFindDuplicates()) {
results = new ArrayList();
}
for (int i = 0; i < containers.length; i++) {
ISourceContainer container = containers[i];
try {
Object[] objects = container.findSourceElements(name);
if (objects.length > 0) {
if (isFindDuplicates()) {
for (int j = 0; j < objects.length; j++) {
results.add(objects[j]);
}
} else {
if (objects.length == 1) {
return objects;
}
return new Object[]{objects[0]};
}
}
} catch (CoreException e) {
if (single == null) {
single = e;
} else if (multiStatus == null) {
multiStatus = new MultiStatus(DebugPlugin.getUniqueIdentifier(), DebugPlugin.ERROR, new IStatus[]{single.getStatus()}, SourceLookupMessages.Source_Lookup_Error, null);
multiStatus.add(e.getStatus());
} else {
multiStatus.add(e.getStatus());
}
}
}
if (results == null) {
if (multiStatus != null) {
throw new CoreException(multiStatus);
} else if (single != null) {
throw single;
}
return EMPTY;
}
return results.toArray();
}
/**
* Creates the source containers in this composite container.
* Subclasses should override this methods.
*
* @throws CoreException if unable to create the containers
*/
protected abstract ISourceContainer[] createSourceContainers() throws CoreException;
/* (non-Javadoc)
* @see org.eclipse.debug.core.sourcelookup.ISourceContainer#getSourceContainers()
*/
public synchronized ISourceContainer[] getSourceContainers() throws CoreException {
if (fContainers == null) {
fContainers = createSourceContainers();
for (int i = 0; i < fContainers.length; i++) {
ISourceContainer container = fContainers[i];
container.init(getDirector());
}
}
return fContainers;
}
/* (non-Javadoc)
* @see org.eclipse.debug.core.sourcelookup.ISourceContainer#dispose()
*/
public void dispose() {
super.dispose();
if (fContainers != null) {
for (int i = 0; i < fContainers.length; i++) {
ISourceContainer container = fContainers[i];
container.dispose();
}
}
fContainers = null;
}
}