blob: c1a46ff9f33bf384973090b9456c7fdabe76c771 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2005 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.jface.action;
import org.eclipse.core.commands.common.EventManager;
import org.eclipse.jface.util.IPropertyChangeListener;
import org.eclipse.jface.util.PropertyChangeEvent;
/**
* <p>
* Some common functionality to share between implementations of
* <code>IAction</code>. This functionality deals with the property change
* event mechanism.
* </p>
* <p>
* Clients may neither instantiate nor extend this class.
* </p>
* <p>
* <strong>EXPERIMENTAL</strong>. This class or interface has been added as
* part of a work in progress. There is a guarantee neither that this API will
* work nor that it will remain the same. Please do not use this API without
* consulting with the Platform/UI team.
* </p>
*
* @since 3.2
*/
public abstract class AbstractAction extends EventManager implements IAction {
public void addPropertyChangeListener(final IPropertyChangeListener listener) {
addListenerObject(listener);
}
/**
* Notifies any property change listeners that a property has changed. Only
* listeners registered at the time this method is called are notified.
*
* @param event
* the property change event
*
* @see IPropertyChangeListener#propertyChange
*/
protected final void firePropertyChange(final PropertyChangeEvent event) {
final Object[] list = getListeners();
for (int i = 0; i < list.length; ++i) {
((IPropertyChangeListener) list[i]).propertyChange(event);
}
}
/**
* Notifies any property change listeners that a property has changed. Only
* listeners registered at the time this method is called are notified. This
* method avoids creating an event object if there are no listeners
* registered, but calls
* <code>firePropertyChange(PropertyChangeEvent)</code> if there are.
*
* @param propertyName
* the name of the property that has changed
* @param oldValue
* the old value of the property, or <code>null</code> if none
* @param newValue
* the new value of the property, or <code>null</code> if none
*
* @see IPropertyChangeListener#propertyChange
*/
protected final void firePropertyChange(final String propertyName,
final Object oldValue, final Object newValue) {
if (isListenerAttached()) {
firePropertyChange(new PropertyChangeEvent(this, propertyName,
oldValue, newValue));
}
}
public void removePropertyChangeListener(
final IPropertyChangeListener listener) {
removeListenerObject(listener);
}
}