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

ca.odell.glazedlists.swt.GlazedListsSWT 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;

// the core Glazed Lists packages

import ca.odell.glazedlists.EventList;
import ca.odell.glazedlists.ThresholdList;
import ca.odell.glazedlists.TransformedList;
import ca.odell.glazedlists.gui.TableFormat;
import ca.odell.glazedlists.impl.swt.*;

import org.eclipse.swt.events.SelectionListener;
import org.eclipse.swt.widgets.*;


/**
 * A factory for creating all sorts of objects to be used with Glazed Lists.
 *
 * @author Jesse Wilson
 */
public final class GlazedListsSWT {

    /**
     * A dummy constructor to prevent instantiation of this class
     */
    private GlazedListsSWT() {
        throw new UnsupportedOperationException();
    }

    // EventLists // // // // // // // // // // // // // // // // // // // // //

    /**
     * Wraps the source in an {@link EventList} that fires all of its update events
     * from the SWT user interface thread.
     */
    public static  TransformedList swtThreadProxyList(EventList source, Display display) {
        return new SWTThreadProxyEventList(source, display);
    }

    /**
     * Returns true if list is an {@link EventList} that fires
     * all of its update events from the SWT event dispatch thread.
     */
    public static boolean isSWTThreadProxyList(EventList list) {
        return list instanceof SWTThreadProxyEventList;
    }

    /**
     * while holding a read lock, this method wraps the given source list with a SWT thread
     * proxy list if necessary.
     */
    static  EventList createProxyListIfNecessary(EventList source, Display display) {
        // lock the source list for reading since we want to prevent writes
        // from occurring until we fully initialize this EventTableModel
        EventList result = source;
        source.getReadWriteLock().readLock().lock();
        try {
            final TransformedList decorated = createSwtThreadProxyListIfNecessary(source, display);

            // if the create method actually returned a decorated form of the source,
            // record it so it may later be disposed
            if (decorated != null && decorated != source) {
                result = decorated;
            }
        } finally {
            source.getReadWriteLock().readLock().unlock();
        }
        return result;
    }

    /** wraps the given source list with a SWT thread proxy list, if necessary */
    private static  TransformedList createSwtThreadProxyListIfNecessary(EventList source, Display display) {
        return GlazedListsSWT.isSWTThreadProxyList(source) ? null : GlazedListsSWT.swtThreadProxyList(source, display);
    }


    // ItemFormats // // // // // // // // // // // // // // // // // // //

    /**
	 * Creates a new {@link ItemFormat} that uses the string value of a JavaBean
	 * property as the formatted value of a list element. If the list element or
	 * the propery value is null, the emtpy string is returned.
	 *
	 * @param propertyName the JavaBean property name
     */
    public static  ItemFormat beanItemFormat(String property) {
        return new BeanItemFormat(property);
    }

    /**
	 * Creates a new {@link ItemFormat} that uses the string value of a JavaBean
	 * property as the formatted value of a list element. If the list element or
	 * the propery value is null, the given value is returned.
	 *
	 * @param propertyName the JavaBean property name
	 * @param valueForNullElement
	 *            string value to be used for a null element or
	 *            property value
     */
    public static  ItemFormat beanItemFormat(String property, String valueForNullElement) {
        return new BeanItemFormat(property, valueForNullElement);
    }

    // ThresholdViewers // // // // // // // // // // // // // // // // // // //

    /**
     * Creates a viewer that manipulates the lower bound of the specified
     * ThresholdList based on changes to the Slider.  The ThresholdList linked
     * to this viewer type will contain a range of Objects between the results
     * of getSelection() and getMaximum() on the Slider.
     */
    public static SelectionListener lowerThresholdViewer(ThresholdList thresholdList, Slider slider) {
        return new LowerThresholdViewer(thresholdList, BoundedRangeControlFactory.slider(slider));
    }

    /**
     * Creates a viewer that manipulates the lower bound of the specified
     * ThresholdList based on changes to Scale selection.  The ThresholdList
     * linked to this viewer type will contain a range of Objects between the
     * results of getSelection() and getMaximum() on the Scale.
     */
    public static SelectionListener lowerThresholdViewer(ThresholdList thresholdList, Scale scale) {
        return new LowerThresholdViewer(thresholdList, BoundedRangeControlFactory.scale(scale));
    }

    /**
     * Creates a viewer that manipulates the upper bound of the specified
     * ThresholdList based on changes to the Slider.  The ThresholdList linked
     * to this model type will contain a range of Objects between the results
     * of getMinimum() and getSelection() on the Slider.
     */
    public static SelectionListener upperThresholdViewer(ThresholdList thresholdList, Slider slider) {
        return new UpperThresholdViewer(thresholdList, BoundedRangeControlFactory.slider(slider));
    }

    /**
     * Creates a viewer that manipulates the upper bound of the specified
     * ThresholdList based on changes to Scale selection.  The ThresholdList
     * linked to this viewer type will contain a range of Objects between the
     * results of getMinimum() and getSelection() on the Scale.
     */
    public static SelectionListener upperThresholdViewer(ThresholdList thresholdList, Scale scale) {
        return new UpperThresholdViewer(thresholdList, BoundedRangeControlFactory.scale(scale));
    }

    // Viewer convenience factory methods

    /**
     * Creates a new viewer for the given {@link Table} that updates the table
     * contents in response to changes on the specified {@link EventList}. The
     * {@link Table} is formatted with the specified {@link TableFormat}.
     *
     * 

The returned viewer is not thread-safe. Unless otherwise * noted, all methods are only safe to be called from the SWT event handler thread. * To do this programmatically, use {@link Display#syncExec(Runnable)} and * wrap the source list (or some part of the source list's pipeline) using * {@link GlazedListsSWT#swtThreadProxyList(EventList, Display)}. *

* * @param source the EventList that provides the row objects * @param table the Table viewing the source objects * @param tableFormat the object responsible for extracting column data * from the row objects */ public static DefaultEventTableViewer eventTableViewer(EventList source, Table table, TableFormat tableFormat) { return new DefaultEventTableViewer(source, table, tableFormat, TableItemConfigurer.DEFAULT); } /** * Creates a new viewer for the given {@link Table} that updates the table * contents in response to changes on the specified {@link EventList}. The * {@link Table} is formatted with the specified {@link TableFormat}. * *

The returned viewer is not thread-safe. Unless otherwise * noted, all methods are only safe to be called from the SWT event handler thread. * To do this programmatically, use {@link Display#syncExec(Runnable)} and * wrap the source list (or some part of the source list's pipeline) using * {@link GlazedListsSWT#swtThreadProxyList(EventList, Display)}. *

* * @param source the EventList that provides the row objects * @param table the Table viewing the source objects * @param tableFormat the object responsible for extracting column data * from the row objects * @param tableItemConfigurer responsible for configuring table items */ public static DefaultEventTableViewer eventTableViewer(EventList source, Table table, TableFormat tableFormat, TableItemConfigurer tableItemConfigurer) { return new DefaultEventTableViewer(source, table, tableFormat, tableItemConfigurer); } /** * Creates a new viewer for the given {@link Table} that updates the table * contents in response to changes on the specified {@link EventList}. The * {@link Table} is formatted with the specified {@link TableFormat}. * While holding a read lock, this method wraps the source list using * {@link GlazedListsSWT#swtThreadProxyList(EventList, Display)}. * *

The returned viewer is not thread-safe. Unless otherwise * noted, all methods are only safe to be called from the SWT event handler thread. *

* * @param source the EventList that provides the row objects * @param table the Table viewing the source objects * @param tableFormat the object responsible for extracting column data * from the row objects */ public static DefaultEventTableViewer eventTableViewerWithThreadProxyList(EventList source, Table table, TableFormat tableFormat) { final EventList proxySource = createSwtThreadProxyListWithLock(source, table.getDisplay()); return new DefaultEventTableViewer(proxySource, table, tableFormat, TableItemConfigurer.DEFAULT, true); } /** * Creates a new viewer for the given {@link Table} that updates the table * contents in response to changes on the specified {@link EventList}. The * {@link Table} is formatted with the specified {@link TableFormat}. * While holding a read lock, this method wraps the source list using * {@link GlazedListsSWT#swtThreadProxyList(EventList, Display)}. * *

The returned viewer is not thread-safe. Unless otherwise * noted, all methods are only safe to be called from the SWT event handler thread. *

* * @param source the EventList that provides the row objects * @param table the Table viewing the source objects * @param tableFormat the object responsible for extracting column data * from the row objects * @param tableItemConfigurer responsible for configuring table items */ public static DefaultEventTableViewer eventTableViewerWithThreadProxyList(EventList source, Table table, TableFormat tableFormat, TableItemConfigurer tableItemConfigurer) { final EventList proxySource = createSwtThreadProxyListWithLock(source, table.getDisplay()); return new DefaultEventTableViewer(proxySource, table, tableFormat, tableItemConfigurer, true); } /** * Creates a new List that displays and responds to changes in the source list. * List elements will simply be displayed as the result of calling * toString() on the contents of the source list. * *

The returned viewer is not thread-safe. Unless otherwise * noted, all methods are only safe to be called from the SWT event handler thread. * To do this programmatically, use {@link Display#syncExec(Runnable)} and * wrap the source list (or some part of the source list's pipeline) using * {@link GlazedListsSWT#swtThreadProxyList(EventList, Display)}. *

* * @param source the EventList that provides the elements * @param list the list */ public static DefaultEventListViewer eventListViewer(EventList source, List list) { return new DefaultEventListViewer(source, list); } /** * Creates a new List that displays and responds to changes in the source list. * List elements are formatted using the provided {@link ItemFormat}. * *

The returned viewer is not thread-safe. Unless otherwise * noted, all methods are only safe to be called from the SWT event handler thread. * To do this programmatically, use {@link Display#syncExec(Runnable)} and * wrap the source list (or some part of the source list's pipeline) using * {@link GlazedListsSWT#swtThreadProxyList(EventList, Display)}. *

* * @param source the EventList that provides the elements * @param list the list * @param itemFormat an {@link ItemFormat} for formatting the displayed values */ public static DefaultEventListViewer eventListViewer(EventList source, List list, ItemFormat itemFormat) { return new DefaultEventListViewer(source, list, itemFormat); } /** * Creates a new List that displays and responds to changes in the source list. * List elements will simply be displayed as the result of calling * toString() on the contents of the source list. * While holding a read lock, this method wraps the source list using * {@link GlazedListsSWT#swtThreadProxyList(EventList, Display)}. * *

The returned viewer is not thread-safe. Unless otherwise * noted, all methods are only safe to be called from the SWT event handler thread. *

* * @param source the EventList that provides the elements * @param list the list */ public static DefaultEventListViewer eventListViewerWithThreadProxyList(EventList source, List list) { final EventList proxySource = createSwtThreadProxyListWithLock(source, list.getDisplay()); return new DefaultEventListViewer(proxySource, list, new DefaultItemFormat(), true); } /** * Creates a new List that displays and responds to changes in the source list. * List elements are formatted using the provided {@link ItemFormat}. * While holding a read lock, this method wraps the source list using * {@link GlazedListsSWT#swtThreadProxyList(EventList, Display)}. * *

The returned viewer is not thread-safe. Unless otherwise * noted, all methods are only safe to be called from the SWT event handler thread. *

* * @param source the EventList that provides the elements * @param list the list * @param itemFormat an {@link ItemFormat} for formatting the displayed values */ public static DefaultEventListViewer eventListViewerWithThreadProxyList(EventList source, List list, ItemFormat itemFormat) { final EventList proxySource = createSwtThreadProxyListWithLock(source, list.getDisplay()); return new DefaultEventListViewer(proxySource, list, itemFormat, true); } /** * 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. * *

The returned viewer is not thread-safe. Unless otherwise * noted, all methods are only safe to be called from the SWT event handler thread. * To do this programmatically, use {@link Display#syncExec(Runnable)} and * wrap the source list (or some part of the source list's pipeline) using * {@link GlazedListsSWT#swtThreadProxyList(EventList, Display)}. *

* * @param source the EventList that provides the elements * @param combo the combo box */ public static DefaultEventComboViewer eventComboViewer(EventList source, Combo combo) { return new DefaultEventComboViewer(source, combo); } /** * 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} component will be * formatted using the provided {@link ItemFormat}. * *

The returned viewer is not thread-safe. Unless otherwise * noted, all methods are only safe to be called from the SWT event handler thread. * To do this programmatically, use {@link Display#syncExec(Runnable)} and * wrap the source list (or some part of the source list's pipeline) using * {@link GlazedListsSWT#swtThreadProxyList(EventList, Display)}. *

* * @param source the EventList that provides the elements * @param combo the combo box * @param itemFormat an {@link ItemFormat} for formatting the displayed values */ public static DefaultEventComboViewer eventComboViewer(EventList source, Combo combo, ItemFormat itemFormat) { return new DefaultEventComboViewer(source, combo, itemFormat); } /** * 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. * While holding a read lock, this method wraps the source list using * {@link GlazedListsSWT#swtThreadProxyList(EventList, Display)}. * *

The returned viewer is not thread-safe. Unless otherwise * noted, all methods are only safe to be called from the SWT event handler thread. *

* * @param source the EventList that provides the elements * @param combo the combo box */ public static DefaultEventComboViewer eventComboViewerWithThreadProxyList(EventList source, Combo combo) { final EventList proxySource = createSwtThreadProxyListWithLock(source, combo.getDisplay()); return new DefaultEventComboViewer(proxySource, combo, new DefaultItemFormat(), true); } /** * 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} component will be * formatted using the provided {@link ItemFormat}. * While holding a read lock, this method wraps the source list using * {@link GlazedListsSWT#swtThreadProxyList(EventList, Display)}. * *

The returned viewer is not thread-safe. Unless otherwise * noted, all methods are only safe to be called from the SWT event handler thread. *

* * @param source the EventList that provides the elements * @param combo the combo box * @param itemFormat an {@link ItemFormat} for formatting the displayed values */ public static DefaultEventComboViewer eventComboViewerWithThreadProxyList(EventList source, Combo combo, ItemFormat itemFormat) { final EventList proxySource = createSwtThreadProxyListWithLock(source, combo.getDisplay()); return new DefaultEventComboViewer(proxySource, combo, itemFormat, true); } /** Helper method to create a SwtThreadProxyList with read locks. */ static EventList createSwtThreadProxyListWithLock(EventList source, Display display) { final EventList result; source.getReadWriteLock().readLock().lock(); try { result = GlazedListsSWT.swtThreadProxyList(source, display); } finally { source.getReadWriteLock().readLock().unlock(); } return result; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy