Package org.apache.commons.beanutils
Class WrapDynaBean
- java.lang.Object
-
- org.apache.commons.beanutils.WrapDynaBean
-
- All Implemented Interfaces:
java.io.Serializable,DynaBean
- Direct Known Subclasses:
ConvertingWrapDynaBean
public class WrapDynaBean extends java.lang.Object implements DynaBean, java.io.Serializable
Implements
DynaBeanto wrap a standard JavaBean instance, so that DynaBean APIs can be used to access its properties.The most common use cases for this class involve wrapping an existing java bean. (This makes it different from the typical use cases for other
DynaBean's.) For example:Object aJavaBean = ...; ... DynaBean db = new WrapDynaBean(aJavaBean); ...
IMPLEMENTATION NOTE - This implementation does not support the
contains()andremove()methods.- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description protected WrapDynaClassdynaClassTheDynaClass"base class" that this DynaBean is associated with.protected java.lang.ObjectinstanceThe JavaBean instance wrapped by this WrapDynaBean.private static longserialVersionUID
-
Constructor Summary
Constructors Constructor Description WrapDynaBean(java.lang.Object instance)Construct a newDynaBeanassociated with the specified JavaBean instance.WrapDynaBean(java.lang.Object instance, WrapDynaClass cls)Creates a new instance ofWrapDynaBean, associates it with the specified JavaBean instance, and initializes the bean'sDynaClass.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description booleancontains(java.lang.String name, java.lang.String key)Does the specified mapped property contain a value for the specified key value?java.lang.Objectget(java.lang.String name)Return the value of a simple property with the specified name.java.lang.Objectget(java.lang.String name, int index)Return the value of an indexed property with the specified name.java.lang.Objectget(java.lang.String name, java.lang.String key)Return the value of a mapped property with the specified name, ornullif there is no value for the specified key.DynaClassgetDynaClass()Return theDynaClassinstance that describes the set of properties available for this DynaBean.protected DynaPropertygetDynaProperty(java.lang.String name)Return the property descriptor for the specified property name.java.lang.ObjectgetInstance()Gets the bean instance wrapped by this DynaBean.private PropertyUtilsBeangetPropertyUtils()Returns thePropertyUtilsBeaninstance to be used for accessing properties.voidremove(java.lang.String name, java.lang.String key)Remove any existing value for the specified key on the specified mapped property.voidset(java.lang.String name, int index, java.lang.Object value)Set the value of an indexed property with the specified name.voidset(java.lang.String name, java.lang.Object value)Set the value of a simple property with the specified name.voidset(java.lang.String name, java.lang.String key, java.lang.Object value)Set the value of a mapped property with the specified name.
-
-
-
Field Detail
-
serialVersionUID
private static final long serialVersionUID
- See Also:
- Constant Field Values
-
dynaClass
protected transient WrapDynaClass dynaClass
TheDynaClass"base class" that this DynaBean is associated with.
-
instance
protected java.lang.Object instance
The JavaBean instance wrapped by this WrapDynaBean.
-
-
Constructor Detail
-
WrapDynaBean
public WrapDynaBean(java.lang.Object instance)
Construct a newDynaBeanassociated with the specified JavaBean instance.- Parameters:
instance- JavaBean instance to be wrapped
-
WrapDynaBean
public WrapDynaBean(java.lang.Object instance, WrapDynaClass cls)Creates a new instance ofWrapDynaBean, associates it with the specified JavaBean instance, and initializes the bean'sDynaClass. Using this constructor thisWrapDynaBeaninstance can be assigned a class which has been configured externally. If noWrapDynaClassis provided, a new one is created using a standard mechanism.- Parameters:
instance- JavaBean instance to be wrappedcls- the optionalWrapDynaClassto be used for this bean- Since:
- 1.9
-
-
Method Detail
-
contains
public boolean contains(java.lang.String name, java.lang.String key)Does the specified mapped property contain a value for the specified key value?- Specified by:
containsin interfaceDynaBean- Parameters:
name- Name of the property to checkkey- Name of the key to check- Returns:
trueif the mapped property contains a value for the specified key, otherwisefalse- Throws:
java.lang.IllegalArgumentException- if there is no property of the specified name
-
get
public java.lang.Object get(java.lang.String name)
Return the value of a simple property with the specified name.
-
get
public java.lang.Object get(java.lang.String name, int index)Return the value of an indexed property with the specified name.- Specified by:
getin interfaceDynaBean- Parameters:
name- Name of the property whose value is to be retrievedindex- Index of the value to be retrieved- Returns:
- The indexed property's value
- Throws:
java.lang.IllegalArgumentException- if there is no property of the specified namejava.lang.IllegalArgumentException- if the specified property exists, but is not indexedjava.lang.IndexOutOfBoundsException- if the specified index is outside the range of the underlying propertyjava.lang.NullPointerException- if no array or List has been initialized for this property
-
get
public java.lang.Object get(java.lang.String name, java.lang.String key)Return the value of a mapped property with the specified name, ornullif there is no value for the specified key.- Specified by:
getin interfaceDynaBean- Parameters:
name- Name of the property whose value is to be retrievedkey- Key of the value to be retrieved- Returns:
- The mapped property's value
- Throws:
java.lang.IllegalArgumentException- if there is no property of the specified namejava.lang.IllegalArgumentException- if the specified property exists, but is not mapped
-
getDynaClass
public DynaClass getDynaClass()
Return theDynaClassinstance that describes the set of properties available for this DynaBean.- Specified by:
getDynaClassin interfaceDynaBean- Returns:
- The associated DynaClass
-
getDynaProperty
protected DynaProperty getDynaProperty(java.lang.String name)
Return the property descriptor for the specified property name.- Parameters:
name- Name of the property for which to retrieve the descriptor- Returns:
- The descriptor for the specified property
- Throws:
java.lang.IllegalArgumentException- if this is not a valid property name for our DynaClass
-
getInstance
public java.lang.Object getInstance()
Gets the bean instance wrapped by this DynaBean. For most common use cases, this object should already be known and this method safely be ignored. But some creators of frameworks usingDynaBean's may find this useful.- Returns:
- the java bean Object wrapped by this
DynaBean
-
getPropertyUtils
private PropertyUtilsBean getPropertyUtils()
Returns thePropertyUtilsBeaninstance to be used for accessing properties. If available, this object is obtained from the associatedWrapDynaClass.- Returns:
- the associated
PropertyUtilsBean
-
remove
public void remove(java.lang.String name, java.lang.String key)Remove any existing value for the specified key on the specified mapped property.
-
set
public void set(java.lang.String name, int index, java.lang.Object value)Set the value of an indexed property with the specified name.- Specified by:
setin interfaceDynaBean- Parameters:
name- Name of the property whose value is to be setindex- Index of the property to be setvalue- Value to which this property is to be set- Throws:
ConversionException- if the specified value cannot be converted to the type required for this propertyjava.lang.IllegalArgumentException- if there is no property of the specified namejava.lang.IllegalArgumentException- if the specified property exists, but is not indexedjava.lang.IndexOutOfBoundsException- if the specified index is outside the range of the underlying property
-
set
public void set(java.lang.String name, java.lang.Object value)Set the value of a simple property with the specified name.- Specified by:
setin interfaceDynaBean- Parameters:
name- Name of the property whose value is to be setvalue- Value to which this property is to be set- Throws:
ConversionException- if the specified value cannot be converted to the type required for this propertyjava.lang.IllegalArgumentException- if there is no property of the specified namejava.lang.NullPointerException- if an attempt is made to set a primitive property to null
-
set
public void set(java.lang.String name, java.lang.String key, java.lang.Object value)Set the value of a mapped property with the specified name.- Specified by:
setin interfaceDynaBean- Parameters:
name- Name of the property whose value is to be setkey- Key of the property to be setvalue- Value to which this property is to be set- Throws:
ConversionException- if the specified value cannot be converted to the type required for this propertyjava.lang.IllegalArgumentException- if there is no property of the specified namejava.lang.IllegalArgumentException- if the specified property exists, but is not mapped
-
-