/*******************************************************************************
* Copyright (c) 2006-2013 The RCP Company 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:
* The RCP Company - initial API and implementation
*******************************************************************************/
package com.rcpcompany.uibindings.internal.observables;
import org.eclipse.core.databinding.observable.Realm;
import org.eclipse.core.databinding.observable.value.AbstractObservableValue;
import org.eclipse.jface.databinding.swt.ISWTObservableValue;
import org.eclipse.jface.databinding.swt.SWTObservables;
import org.eclipse.swt.events.DisposeEvent;
import org.eclipse.swt.events.DisposeListener;
import org.eclipse.swt.widgets.Widget;
/**
* Copied strait out of
* {@link org.eclipse.jface.internal.databinding.provisional.swt.AbstractSWTObservableValue}.
*/
public abstract class AbstractSWTObservableValue extends AbstractObservableValue implements ISWTObservableValue {
private final Widget widget;
/**
* Standard constructor for an SWT ObservableValue. Makes sure that the observable gets disposed
* when the SWT widget is disposed.
*
* @param widget
*/
protected AbstractSWTObservableValue(Widget widget) {
this(SWTObservables.getRealm(widget.getDisplay()), widget);
}
/**
* Constructor that allows for the setting of the realm. Makes sure that the observable gets
* disposed when the SWT widget is disposed.
*
* @param realm
* @param widget
*/
protected AbstractSWTObservableValue(Realm realm, Widget widget) {
super(realm);
this.widget = widget;
widget.addDisposeListener(disposeListener);
}
@Override
public synchronized void dispose() {
if (!widget.isDisposed()) {
widget.removeDisposeListener(disposeListener);
}
super.dispose();
}
/**
* Dispose listener for the backed SWT widget. Not just added/removed in
* {@link #firstListenerAdded()} and {@link #lastListenerRemoved()} as we want to track disposal
* of the widget even if we don't have any listeners.
*/
private final DisposeListener disposeListener = new DisposeListener() {
@Override
public void widgetDisposed(DisposeEvent e) {
AbstractSWTObservableValue.this.dispose();
}
};
/**
* @return Returns the widget.
*/
@Override
public Widget getWidget() {
return widget;
}
}