All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ca.odell.glazedlists.swt.EventComboViewer Maven / Gradle / Ivy

There is a newer version: 1.9.1
Show newest version
/* Glazed Lists                                                 (c) 2003-2006 */
/* http://publicobject.com/glazedlists/                      publicboject.com,*/
/*                                                     O'Dell Engineering Ltd.*/
package ca.odell.glazedlists.swt;

import ca.odell.glazedlists.EventList;

import org.eclipse.swt.widgets.Combo;
import org.eclipse.swt.widgets.Display;

/**
 * A view helper that displays an {@link EventList} in a {@link Combo} component.
 *
 * 

This class is not thread safe. It must be used exclusively with the SWT * event handler thread. * * @deprecated Use {@link DefaultEventComboViewer} instead. This class will be removed in the GL * 2.0 release. The wrapping of the source list with an SWT-EDT safe list has been * determined to be undesirable (it is better for the user to provide their own SWT-EDT * safe list). * * @author Kevin Maltby * @author Holger Brands */ public class EventComboViewer extends DefaultEventComboViewer { /** indicates, if source list has to be disposed */ private boolean disposeSource; /** * Binds the contents of a {@link Combo} component to an {@link EventList} * source. This allows the selection choices in a {@link Combo} to change * dynamically to reflect chances to the source {@link EventList}. The * {@link String} values displayed in the {@link Combo} compoment will be * the result of calling toString() on the Objects found in source. */ public EventComboViewer(EventList source, Combo combo) { this(source, combo, new DefaultItemFormat()); } /** * Binds the contents of a {@link Combo} component to an {@link EventList} * source. This allows the selection choices in a {@link Combo} to change * dynamically to reflect chances to the source {@link EventList}. The * {@link String} values displayed in the {@link Combo} compoment will be * formatted using the provided {@link ItemFormat}. * * @see ItemFormat * @see GlazedListsSWT#beanItemFormat(String) */ public EventComboViewer(EventList source, Combo combo, ItemFormat itemFormat) { super(createProxyList(source, combo.getDisplay()), combo, itemFormat); disposeSource = (this.source != source); } /** * Releases the resources consumed by this {@link EventComboViewer} so that it * may eventually be garbage collected. * *

An {@link EventComboViewer} will be garbage collected without a call to * {@link #dispose()}, but not before its source {@link EventList} is garbage * collected. By calling {@link #dispose()}, you allow the {@link EventComboViewer} * to be garbage collected before its source {@link EventList}. This is * necessary for situations where an {@link EventComboViewer} is short-lived but * its source {@link EventList} is long-lived. * *

Warning: It is an error * to call any method on a {@link EventComboViewer} after it has been disposed. */ public void dispose() { if (disposeSource) source.dispose(); super.dispose(); } /** * while holding a read lock, this method wraps the given source list with a SWT thread * proxy list. */ private static EventList createProxyList(EventList source, Display display) { return GlazedListsSWT.createProxyListIfNecessary(source, display); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy