/********************************************************************** * Copyright (c) 2003 IBM Corporation and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Common Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/cpl-v10.html �* * Contributors: * IBM - Initial API and implementation **********************************************************************/ package net.sourceforge.phpdt.httpquery.preferences; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import net.sourceforge.phpdt.httpquery.config.IConfiguration; import net.sourceforge.phpdt.phphelp.PHPHelpPlugin; import org.eclipse.jface.viewers.IStructuredContentProvider; import org.eclipse.jface.viewers.Viewer; /** * Configuration content provider. */ public class ConfigurationContentProvider implements IStructuredContentProvider { /** * ConfigurationContentProvider constructor comment. */ public ConfigurationContentProvider() { super(); } /** * Disposes of this content provider. This is called by the viewer when it * is disposed. */ public void dispose() { } /** * Returns the elements to display in the viewer when its input is set to * the given element. These elements can be presented as rows in a table, * items in a list, etc. The result is not modified by the viewer. * * @param inputElement * the input element * @return the array of elements to display in the viewer */ public Object[] getElements(Object inputElement) { List list = new ArrayList(); Iterator iterator = PHPHelpPlugin.getConfigurations().iterator(); while (iterator.hasNext()) { IConfiguration configuration = (IConfiguration) iterator.next(); list.add(configuration); } return list.toArray(); } /** * Notifies this content provider that the given viewer's input has been * switched to a different element. * <p> * A typical use for this method is registering the content provider as a * listener to changes on the new input (using model-specific means), and * deregistering the viewer from the old input. In response to these change * notifications, the content provider propagates the changes to the viewer. * </p> * * @param viewer * the viewer * @param oldInput * the old input element, or <code>null</code> if the viewer * did not previously have an input * @param newInput * the new input element, or <code>null</code> if the viewer * does not have an input */ public void inputChanged(Viewer viewer, Object oldInput, Object newInput) { } }