java.beans
Class PropertyDescriptor

java.lang.Object
  |
  +--java.beans.FeatureDescriptor
        |
        +--java.beans.PropertyDescriptor
Direct Known Subclasses:
IndexedPropertyDescriptor

public class PropertyDescriptor
extends FeatureDescriptor

A PropertyDescriptor describes one property that a Java Bean exports via a pair of accessor methods.


Field Summary
private  boolean bound
           
private  boolean constrained
           
private  Class propertyEditorClass
           
private  Class propertyType
           
private  java.lang.reflect.Method readMethod
           
private  java.lang.reflect.Method writeMethod
           
 
Fields inherited from class java.beans.FeatureDescriptor
displayName, expert, hidden, name, preferred, shortDescription, table
 
Constructor Summary
(package private) PropertyDescriptor(PropertyDescriptor old)
           
(package private) PropertyDescriptor(PropertyDescriptor x, PropertyDescriptor y)
           
  PropertyDescriptor(String propertyName, Class beanClass)
          Constructs a PropertyDescriptor for a property that follows the standard Java convention by having getFoo and setFoo accessor methods.
  PropertyDescriptor(String propertyName, Class beanClass, String getterName, String setterName)
          This constructor takes the name of a simple property, and method names for reading and writing the property.
  PropertyDescriptor(String propertyName, java.lang.reflect.Method getter, java.lang.reflect.Method setter)
          This constructor takes the name of a simple property, and Method objects for reading and writing the property.
 
Method Summary
(package private) static String capitalize(String s)
           
private  void findPropertyType()
           
 Class getPropertyEditorClass()
          Gets any explicit PropertyEditor Class that has been registered for this property.
 Class getPropertyType()
          Gets the Class object for the property.
 java.lang.reflect.Method getReadMethod()
          Gets the method that should be used to read the property value.
 java.lang.reflect.Method getWriteMethod()
          Gets the method that should be used to write the property value.
 boolean isBound()
          Updates to "bound" properties will cause a "PropertyChange" event to get fired when the property is changed.
 boolean isConstrained()
          Attempted updates to "Constrained" properties will cause a "VetoableChange" event to get fired when the property is changed.
 void setBound(boolean bound)
          Updates to "bound" properties will cause a "PropertyChange" event to get fired when the property is changed.
 void setConstrained(boolean constrained)
          Attempted updates to "Constrained" properties will cause a "VetoableChange" event to get fired when the property is changed.
 void setPropertyEditorClass(Class propertyEditorClass)
          Normally PropertyEditors will be found using the PropertyEditorManager.
 void setReadMethod(java.lang.reflect.Method getter)
          Sets the method that should be used to read the property value.
 void setWriteMethod(java.lang.reflect.Method setter)
          Sets the method that should be used to write the property value.
 
Methods inherited from class java.beans.FeatureDescriptor
addTable, attributeNames, getDisplayName, getName, getShortDescription, getValue, isExpert, isHidden, isPreferred, setDisplayName, setExpert, setHidden, setName, setPreferred, setShortDescription, setValue
 
Methods inherited from class java.lang.Object
, clone, equals, finalize, getClass, hashCode, notify, notifyAll, registerNatives, toString, wait, wait, wait
 

Field Detail

propertyType

private Class propertyType

readMethod

private java.lang.reflect.Method readMethod

writeMethod

private java.lang.reflect.Method writeMethod

bound

private boolean bound

constrained

private boolean constrained

propertyEditorClass

private Class propertyEditorClass
Constructor Detail

PropertyDescriptor

public PropertyDescriptor(String propertyName,
                          Class beanClass)
                   throws IntrospectionException
Constructs a PropertyDescriptor for a property that follows the standard Java convention by having getFoo and setFoo accessor methods. Thus if the argument name is "fred", it will assume that the writer method is "setFred" and the writer method is "getFred" (or "isFred" for a boolean property). Note that the property name should start with a lower case character, which will be capitalized in the method names.
Parameters:
propertyName - The programmatic name of the property.
beanClass - The Class object for the target bean. For example sun.beans.OurButton.class.
Throws:
IntrospectionException - if an exception occurs during introspection.

PropertyDescriptor

public PropertyDescriptor(String propertyName,
                          Class beanClass,
                          String getterName,
                          String setterName)
                   throws IntrospectionException
This constructor takes the name of a simple property, and method names for reading and writing the property.
Parameters:
propertyName - The programmatic name of the property.
beanClass - The Class object for the target bean. For example sun.beans.OurButton.class.
getterName - The name of the method used for reading the property value. May be null if the property is write-only.
setterName - The name of the method used for writing the property value. May be null if the property is read-only.
Throws:
IntrospectionException - if an exception occurs during introspection.

PropertyDescriptor

public PropertyDescriptor(String propertyName,
                          java.lang.reflect.Method getter,
                          java.lang.reflect.Method setter)
                   throws IntrospectionException
This constructor takes the name of a simple property, and Method objects for reading and writing the property.
Parameters:
propertyName - The programmatic name of the property.
getter - The method used for reading the property value. May be null if the property is write-only.
setter - The method used for writing the property value. May be null if the property is read-only.
Throws:
IntrospectionException - if an exception occurs during introspection.

PropertyDescriptor

PropertyDescriptor(PropertyDescriptor x,
                   PropertyDescriptor y)

PropertyDescriptor

PropertyDescriptor(PropertyDescriptor old)
Method Detail

getPropertyType

public Class getPropertyType()
Gets the Class object for the property.
Returns:
The Java type info for the property. Note that the "Class" object may describe a built-in Java type such as "int". The result may be "null" if this is an indexed property that does not support non-indexed access.

This is the type that will be returned by the ReadMethod.


getReadMethod

public java.lang.reflect.Method getReadMethod()
Gets the method that should be used to read the property value.
Returns:
The method that should be used to read the property value. May return null if the property can't be read.

setReadMethod

public void setReadMethod(java.lang.reflect.Method getter)
                   throws IntrospectionException
Sets the method that should be used to read the property value.
Parameters:
getter - The new getter method.

getWriteMethod

public java.lang.reflect.Method getWriteMethod()
Gets the method that should be used to write the property value.
Returns:
The method that should be used to write the property value. May return null if the property can't be written.

setWriteMethod

public void setWriteMethod(java.lang.reflect.Method setter)
                    throws IntrospectionException
Sets the method that should be used to write the property value.
Parameters:
setter - The new setter method.

isBound

public boolean isBound()
Updates to "bound" properties will cause a "PropertyChange" event to get fired when the property is changed.
Returns:
True if this is a bound property.

setBound

public void setBound(boolean bound)
Updates to "bound" properties will cause a "PropertyChange" event to get fired when the property is changed.
Parameters:
bound - True if this is a bound property.

isConstrained

public boolean isConstrained()
Attempted updates to "Constrained" properties will cause a "VetoableChange" event to get fired when the property is changed.
Returns:
True if this is a constrained property.

setConstrained

public void setConstrained(boolean constrained)
Attempted updates to "Constrained" properties will cause a "VetoableChange" event to get fired when the property is changed.
Parameters:
constrained - True if this is a constrained property.

setPropertyEditorClass

public void setPropertyEditorClass(Class propertyEditorClass)
Normally PropertyEditors will be found using the PropertyEditorManager. However if for some reason you want to associate a particular PropertyEditor with a given property, then you can do it with this method.
Parameters:
propertyEditorClass - The Class for the desired PropertyEditor.

getPropertyEditorClass

public Class getPropertyEditorClass()
Gets any explicit PropertyEditor Class that has been registered for this property.
Returns:
Any explicit PropertyEditor Class that has been registered for this property. Normally this will return "null", indicating that no special editor has been registered, so the PropertyEditorManager should be used to locate a suitable PropertyEditor.

findPropertyType

private void findPropertyType()
                       throws IntrospectionException

capitalize

static String capitalize(String s)