public class BeanMap
extends java.util.AbstractMap<java.lang.String,java.lang.Object>
implements java.lang.Cloneable
Modifier and Type | Class and Description |
---|---|
protected static class |
BeanMap.MyMapEntry
Map entry used by
BeanMap . |
Constructor and Description |
---|
BeanMap()
Constructs a new empty
BeanMap . |
BeanMap(java.lang.Object bean)
Constructs a new
BeanMap that operates on the
specified bean. |
Modifier and Type | Method and Description |
---|---|
void |
clear()
This method reinitializes the bean map to have default values for the
bean's properties.
|
java.lang.Object |
clone()
Clone this bean map using the following process:
If there is no underlying bean, return a cloned BeanMap without a
bean.
|
boolean |
containsKey(java.lang.String name)
Returns true if the bean defines a property with the given name.
|
protected java.lang.Object |
convertType(java.lang.Class<?> newType,
java.lang.Object value)
Converts the given value to the given type.
|
protected java.lang.Object[] |
createWriteMethodArguments(java.lang.reflect.Method method,
java.lang.Object value)
Creates an array of parameters to pass to the given mutator method.
|
java.util.Iterator<java.util.Map.Entry<java.lang.String,java.lang.Object>> |
entryIterator()
Convenience method for getting an iterator over the entries.
|
java.util.Set<java.util.Map.Entry<java.lang.String,java.lang.Object>> |
entrySet()
Gets a Set of MapEntry objects that are the mappings for this BeanMap.
|
protected void |
firePropertyChange(java.lang.String key,
java.lang.Object oldValue,
java.lang.Object newValue)
Called during a successful
AbstractMap.put(Object,Object) operation. |
java.lang.Object |
get(java.lang.String name)
Returns the value of the bean's property with the given name.
|
java.lang.Object |
getBean()
Returns the bean currently being operated on.
|
java.lang.reflect.Method |
getReadMethod(java.lang.String name)
Returns the accessor for the property with the given name.
|
java.lang.Class<?> |
getType(java.lang.String name)
Returns the type of the property with the given name.
|
protected com.google.common.base.Function<?,?> |
getTypeFunction(java.lang.Class<?> aType)
Returns a transformer for the given primitive type.
|
java.lang.reflect.Method |
getWriteMethod(java.lang.String name)
Returns the mutator for the property with the given name.
|
java.util.Iterator<java.lang.String> |
keyIterator()
Convenience method for getting an iterator over the keys.
|
java.util.Set<java.lang.String> |
keySet()
Get the keys for this BeanMap.
|
java.lang.Object |
put(java.lang.String name,
java.lang.Object value)
Sets the bean property with the given name to the given value.
|
void |
putAllWriteable(BeanMap map)
Puts all of the writable properties from the given BeanMap into this
BeanMap.
|
protected void |
reinitialise()
Reinitializes this bean.
|
void |
setBean(java.lang.Object newBean)
Sets the bean to be operated on by this map.
|
int |
size()
Returns the number of properties defined by the bean.
|
java.lang.String |
toString() |
java.util.Iterator<java.lang.Object> |
valueIterator()
Convenience method for getting an iterator over the values.
|
java.util.Collection<java.lang.Object> |
values()
Returns the values for the BeanMap.
|
public BeanMap()
BeanMap
.public BeanMap(java.lang.Object bean)
BeanMap
that operates on the
specified bean. If the given bean is null
, then
this map will be empty.bean
- the bean for this map to operate onpublic java.lang.String toString()
toString
in class java.util.AbstractMap<java.lang.String,java.lang.Object>
public java.lang.Object clone() throws java.lang.CloneNotSupportedException
clone
in class java.util.AbstractMap<java.lang.String,java.lang.Object>
java.lang.CloneNotSupportedException
public void putAllWriteable(BeanMap map)
map
- the BeanMap whose properties to putpublic void clear()
clear()
differs from the Map contract in that
the mappings are not actually removed from the map (the mappings for a
BeanMap are fixed).clear
in interface java.util.Map<java.lang.String,java.lang.Object>
clear
in class java.util.AbstractMap<java.lang.String,java.lang.Object>
public boolean containsKey(java.lang.String name)
String
; if not, this method
returns false. This method will also return false if the bean
does not define a property with that name.
Write-only properties will not be matched as the test operates against
property read methods.name
- the name of the property to checkString
;
false if the bean does not define a property with that name; or
true if the bean does define a property with that namepublic java.lang.Object get(java.lang.String name)
String
and must not be
null; otherwise, this method returns null
.
If the bean defines a property with the given name, the value of
that property is returned. Otherwise, null
is
returned.
Write-only properties will not be matched as the test operates against
property read methods.name
- the name of the property whose value to returnpublic java.lang.Object put(java.lang.String name, java.lang.Object value) throws java.lang.IllegalArgumentException, java.lang.ClassCastException
put
in interface java.util.Map<java.lang.String,java.lang.Object>
put
in class java.util.AbstractMap<java.lang.String,java.lang.Object>
name
- the name of the property to setvalue
- the value to set that property tojava.lang.IllegalArgumentException
- if the given name is null;
if the given name is not a String
; if the bean doesn't
define a property with that name; or if the bean property with
that name is read-onlyjava.lang.ClassCastException
public int size()
size
in interface java.util.Map<java.lang.String,java.lang.Object>
size
in class java.util.AbstractMap<java.lang.String,java.lang.Object>
public java.util.Set<java.lang.String> keySet()
keySet
in interface java.util.Map<java.lang.String,java.lang.Object>
keySet
in class java.util.AbstractMap<java.lang.String,java.lang.Object>
public java.util.Set<java.util.Map.Entry<java.lang.String,java.lang.Object>> entrySet()
entrySet
in interface java.util.Map<java.lang.String,java.lang.Object>
entrySet
in class java.util.AbstractMap<java.lang.String,java.lang.Object>
public java.util.Collection<java.lang.Object> values()
values
in interface java.util.Map<java.lang.String,java.lang.Object>
values
in class java.util.AbstractMap<java.lang.String,java.lang.Object>
public java.lang.Class<?> getType(java.lang.String name)
name
- the name of the propertynull
if no such
property existspublic java.util.Iterator<java.lang.String> keyIterator()
public java.util.Iterator<java.lang.Object> valueIterator()
public java.util.Iterator<java.util.Map.Entry<java.lang.String,java.lang.Object>> entryIterator()
public java.lang.Object getBean()
public void setBean(java.lang.Object newBean)
newBean
- the new bean to operate onpublic java.lang.reflect.Method getReadMethod(java.lang.String name)
name
- the name of the propertypublic java.lang.reflect.Method getWriteMethod(java.lang.String name)
name
- the name of the propertyprotected void reinitialise()
setBean(Object)
.
Does introspection to find properties.protected void firePropertyChange(java.lang.String key, java.lang.Object oldValue, java.lang.Object newValue)
AbstractMap.put(Object,Object)
operation.
Default implementation does nothing. Override to be notified of
property changes in the bean caused by this map.key
- the name of the property that changedoldValue
- the old value for that propertynewValue
- the new value for that propertyprotected java.lang.Object[] createWriteMethodArguments(java.lang.reflect.Method method, java.lang.Object value) throws java.lang.IllegalAccessException, java.lang.ClassCastException
convertType(Class,Object)
.method
- the mutator methodvalue
- the value to pass to the mutator methodjava.lang.IllegalAccessException
- if convertType(Class,Object)
raises itjava.lang.IllegalArgumentException
- if any other exception is raised
by convertType(Class,Object)
java.lang.ClassCastException
protected java.lang.Object convertType(java.lang.Class<?> newType, java.lang.Object value) throws java.lang.InstantiationException, java.lang.IllegalAccessException, java.lang.IllegalArgumentException, java.lang.reflect.InvocationTargetException
If no such constructor exists, and the given type is a primitive type, then the given value is converted to a string using its
toString()
method, and that string is
parsed into the correct primitive type using, for instance,
Integer.valueOf(String)
to convert the string into an
int
.If no special constructor exists and the given type is not a primitive type, this method returns the original value.
newType
- the type to convert the value tovalue
- the value to convertjava.lang.NumberFormatException
- if newType is a primitive type, and
the string representation of the given value cannot be converted
to that typejava.lang.InstantiationException
- if the constructor found with
reflection raises itjava.lang.reflect.InvocationTargetException
- if the constructor found with
reflection raises itjava.lang.IllegalAccessException
- neverjava.lang.IllegalArgumentException
- neverprotected com.google.common.base.Function<?,?> getTypeFunction(java.lang.Class<?> aType)
aType
- the primitive type whose transformer to returnCopyright © 2007-2013 Mysema Ltd. All Rights Reserved.