diff options
author | Tom Tromey <tromey@redhat.com> | 2002-07-15 16:05:13 +0000 |
---|---|---|
committer | Tom Tromey <tromey@gcc.gnu.org> | 2002-07-15 16:05:13 +0000 |
commit | 9698ee33f0214f9d85b3ec67f139a0bb605b29bf (patch) | |
tree | aed15e12fb5ec9a4f295ff0702895b39b1a9938a /libjava/java/beans/PropertyChangeEvent.java | |
parent | ed8d29205b130073bd3147cedf068446689a5386 (diff) | |
download | gcc-9698ee33f0214f9d85b3ec67f139a0bb605b29bf.zip gcc-9698ee33f0214f9d85b3ec67f139a0bb605b29bf.tar.gz gcc-9698ee33f0214f9d85b3ec67f139a0bb605b29bf.tar.bz2 |
Makefile.in: Rebuilt.
* Makefile.in: Rebuilt.
* Makefile.am (awt_java_source_files): Added new files.
* java/beans/ExceptionListener.java: Merged with Classpath.
* java/beans/PropertyChangeEvent.java: Merged with Classpath.
* java/beans/PropertyChangeListener.java: Merged with Classpath.
* java/beans/PropertyChangeListenerProxy.java: Merged with Classpath.
* java/beans/PropertyChangeSupport.java: Merged with Classpath.
* java/beans/VetoableChangeListener.java: Merged with Classpath.
* java/beans/VetoableChangeListenerProxy.java: Merged with Classpath.
* java/beans/VetoableChangeSupport.java: Merged with Classpath.
From-SVN: r55459
Diffstat (limited to 'libjava/java/beans/PropertyChangeEvent.java')
-rw-r--r-- | libjava/java/beans/PropertyChangeEvent.java | 237 |
1 files changed, 151 insertions, 86 deletions
diff --git a/libjava/java/beans/PropertyChangeEvent.java b/libjava/java/beans/PropertyChangeEvent.java index d65ca68..83ca681 100644 --- a/libjava/java/beans/PropertyChangeEvent.java +++ b/libjava/java/beans/PropertyChangeEvent.java @@ -1,5 +1,5 @@ -/* java.beans.PropertyChangeEvent - Copyright (C) 1998, 2000 Free Software Foundation, Inc. +/* PropertyChangeEvent.java -- describes a change in a property + Copyright (C) 1998, 2000, 2002 Free Software Foundation, Inc. This file is part of GNU Classpath. @@ -7,7 +7,7 @@ GNU Classpath is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. - + GNU Classpath is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU @@ -38,87 +38,152 @@ exception statement from your version. */ package java.beans; +import java.util.EventObject; + /** - ** PropertyChangeEvents are fired in the PropertyChange - ** and VetoableChange event classes. They represent the - ** old and new values as well as the source Bean.<P> - ** - ** If the old or new value is a primitive type, it must - ** be wrapped in the appropriate wrapper type - ** (java.lang.Integer for int, etc., etc.).<P> - ** - ** If the old or new values are unknown (although why - ** that would be I do not know), they may be null.<P> - ** - ** Right now Sun put in a propagationId, reserved for - ** future use. Read the comments on the constructor - ** and on setPropagationId for more information. - ** - ** @author John Keiser - ** @since JDK1.1 - ** @version 1.1.0, 29 Jul 1998 - **/ - -public class PropertyChangeEvent extends java.util.EventObject { - String propertyName; - Object oldValue; - Object newValue; - Object propagationId; - - private static final long serialVersionUID = 7042693688939648123L; - - /** Create a new PropertyChangeEvent. Remember that if - ** you received a PropertyChangeEvent and are sending - ** a new one, you should also set the propagation ID - ** from the old PropertyChangeEvent. - ** @param source the Bean containing the property. - ** @param propertyName the property's name. - ** @param oldValue the old value of the property. - ** @param newValue the new value of the property. - **/ - public PropertyChangeEvent(Object source, String propertyName, Object oldVal, Object newVal) { - super(source); - this.propertyName = propertyName; - oldValue = oldVal; - newValue = newVal; - } - - /** Get the property name. - ** @return the property name. - **/ - public String getPropertyName() { - return propertyName; - } - - /** Get the property's old value. - ** @return the property's old value. - **/ - public Object getOldValue() { - return oldValue; - } - - /** Get the property's new value. - ** @return the property's new value. - **/ - public Object getNewValue() { - return newValue; - } - - /** Set the propagation ID. This is a way for the event - ** to be passed from hand to hand and retain a little - ** extra state. Right now it is unused, but it should - ** be propagated anyway so that future versions of - ** JavaBeans can use it, for God knows what. - ** @param propagationId the propagation ID. - **/ - public void setPropagationId(Object propagationId) { - this.propagationId = propagationId; - } - - /** Get the propagation ID. - ** @return the propagation ID. - **/ - public Object getPropagationId() { - return propagationId; - } -} + * PropertyChangeEvents are fired in the PropertyChange and VetoableChange + * event classes. They represent the old and new values as well as the + * source Bean. If the old or new value is a primitive type, it must be + * wrapped in the appropriate wrapper type (java.lang.Integer for int, etc., + * etc.). + * + * <p>If the old or new values are unknown (although why that would be I do + * not know), they may be null. Also, if the set of properties itself has + * changed, the name should be null, and the old and new values may also be + * null. Right now Sun put in a propagationId, reserved for future use. Read + * the comments on the constructor and on setPropagationId for more + * information. + * + * @author John Keiser + * @author Eric Blake <ebb9@email.byu.edu> + * @since 1.1 + * @status udpated to 1.4 + */ +public class PropertyChangeEvent extends EventObject +{ + /** + * Compatible with JDK 1.1+. + */ + private static final long serialVersionUID = 7042693688939648123L; + + /** + * The name of the property that changed, may be null. Package visible for + * use by PropertyChangeSupport. + * + * @serial the changed property name + */ + final String propertyName; + + /** + * The new value of the property, may be null. Package visible for use by + * PropertyChangeSupport. + * + * @serial the new property value + */ + final Object newValue; + + /** + * The old value of the property, may be null. Package visible for use by + * PropertyChangeSupport. + * + * @serial the old property value + */ + final Object oldValue; + + /** + * The propagation ID, reserved for future use. May be null. + * + * @see #getPropagationId() + * @serial the Propagation ID + */ + private Object propagationId; + + /** + * Create a new PropertyChangeEvent. Remember that if you received a + * PropertyChangeEvent and are sending a new one, you should also set the + * propagation ID from the old PropertyChangeEvent. + * + * @param source the Bean containing the property + * @param propertyName the property's name + * @param oldValue the old value of the property + * @param newValue the new value of the property + * @throws IllegalArgumentException if source is null + */ + public PropertyChangeEvent(Object source, String propertyName, + Object oldVal, Object newVal) + { + super(source); + this.propertyName = propertyName; + oldValue = oldVal; + newValue = newVal; + } + + /** + * Get the property name. May be null if multiple properties changed. + * + * @return the property name + */ + public String getPropertyName() + { + return propertyName; + } + + /** + * Get the property's new value. May be null if multiple properties changed. + * + * @return the property's new value + */ + public Object getNewValue() + { + return newValue; + } + + /** + * Get the property's old value. May be null if multiple properties changed. + * + * @return the property's old value + */ + public Object getOldValue() + { + return oldValue; + } + + /** + * Set the propagation ID. This is a way for the event to be passed from + * hand to hand and retain a little extra state. Right now it is unused, + * but it should be propagated anyway so that future versions of JavaBeans + * can use it, for God knows what. + * + * @param propagationId the propagation ID + * @see #getPropagationId() + */ + public void setPropagationId(Object propagationId) + { + this.propagationId = propagationId; + } + + /** + * Get the propagation ID. Right now, it is not used for anything. + * + * @return the propagation ID + * @see #setPropagationId(Object) + */ + public Object getPropagationId() + { + return propagationId; + } + + /** + * Utility method to rollback a change. + * + * @param event the event to rollback + * @return a new event with old and new swapped + */ + PropertyChangeEvent rollback() + { + PropertyChangeEvent result + = new PropertyChangeEvent(source, propertyName, newValue, oldValue); + result.propagationId = propagationId; + return result; + } +} // class PropertyChangeEvent |