diff --git a/src/java/org/apache/commons/collections/BeanMap.java b/src/java/org/apache/commons/collections/BeanMap.java index b6fdfd1b0..334fe7f02 100644 --- a/src/java/org/apache/commons/collections/BeanMap.java +++ b/src/java/org/apache/commons/collections/BeanMap.java @@ -1,7 +1,7 @@ /* - * $Header: /home/jerenkrantz/tmp/commons/commons-convert/cvs/home/cvs/jakarta-commons//collections/src/java/org/apache/commons/collections/BeanMap.java,v 1.3 2002/02/10 08:07:42 jstrachan Exp $ - * $Revision: 1.3 $ - * $Date: 2002/02/10 08:07:42 $ + * $Header: /home/jerenkrantz/tmp/commons/commons-convert/cvs/home/cvs/jakarta-commons//collections/src/java/org/apache/commons/collections/BeanMap.java,v 1.4 2002/02/22 07:00:30 mas Exp $ + * $Revision: 1.4 $ + * $Date: 2002/02/22 07:00:30 $ * * ==================================================================== * @@ -178,8 +178,9 @@ public class BeanMap extends AbstractMap { //------------------------------------------------------------------------- public Object clone() { - Class beanClass = bean.getClass(); + Class beanClass = null; try { + beanClass = bean.getClass(); Object newBean = beanClass.newInstance(); Map newMap = new BeanMap( newBean ); newMap.putAll( this ); @@ -190,9 +191,18 @@ public class BeanMap extends AbstractMap { } } + /** + * This method reinitializes the bean map to have default values for the + * bean's properties. This is accomplished by constructing a new instance + * of the bean which th emap uses as its underlying data source. This + * behavior for clear() differs from the Map contract in that + * the mappings are not actually removed from the map (the mappings for a + * BeanMap are fixed). + **/ public void clear() { - Class beanClass = bean.getClass(); + Class beanClass = null; try { + beanClass = bean.getClass(); bean = beanClass.newInstance(); } catch (Exception e) { diff --git a/src/test/org/apache/commons/collections/TestBeanMap.java b/src/test/org/apache/commons/collections/TestBeanMap.java index eb19827b7..b25efd1fc 100644 --- a/src/test/org/apache/commons/collections/TestBeanMap.java +++ b/src/test/org/apache/commons/collections/TestBeanMap.java @@ -1,7 +1,7 @@ /* - * $Header: /home/jerenkrantz/tmp/commons/commons-convert/cvs/home/cvs/jakarta-commons//collections/src/test/org/apache/commons/collections/TestBeanMap.java,v 1.2 2002/02/22 02:18:50 mas Exp $ - * $Revision: 1.2 $ - * $Date: 2002/02/22 02:18:50 $ + * $Header: /home/jerenkrantz/tmp/commons/commons-convert/cvs/home/cvs/jakarta-commons//collections/src/test/org/apache/commons/collections/TestBeanMap.java,v 1.3 2002/02/22 07:00:30 mas Exp $ + * $Revision: 1.3 $ + * $Date: 2002/02/22 07:00:30 $ * * ==================================================================== * @@ -250,6 +250,11 @@ public class TestBeanMap extends TestMap { return values; } + /** + * The mappings in a BeanMap are fixed on the properties the underlying + * bean has. Adding and removing mappings is not possible, thus this + * method is overridden to return false. + **/ public boolean isAddRemoveModifiable() { return false; } @@ -261,4 +266,17 @@ public class TestBeanMap extends TestMap { public Map makeEmptyMap() { return new BeanMap(); } + + /** + * Need to override this method because the "clear()" method on the bean + * map just returns the bean properties to their default states. It does + * not actually remove the mappings as per the map contract. The default + * testClear() methods checks that the clear method throws an + * UnsupportedOperationException since this class is not add/remove + * modifiable. In our case though, we do not always throw that exception. + **/ + public void testClear() { + //TODO: make sure a call to BeanMap.clear returns the bean to its + //default initialization values. + } }