commons-issues mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From "Matt Benson (JIRA)" <>
Subject [jira] [Commented] (COLLECTIONS-231) Not return the base interface on decorate
Date Fri, 20 May 2011 13:34:48 GMT


Matt Benson commented on COLLECTIONS-231:

My vote is for consistency.  I imagine Torsten was thinking broadly when he created this issue
with such a vague title.

> Not return the base interface on decorate
> -----------------------------------------
>                 Key: COLLECTIONS-231
>                 URL:
>             Project: Commons Collections
>          Issue Type: Improvement
>          Components: Map
>    Affects Versions: 3.2
>            Reporter: Torsten Curdt
>             Fix For: 4.0-beta-1
> At the moment I don't see a reason why the static "decorate" method does not return ListOrderedMap
but just the base interface OrderedMap.
> I want to decorate a Map to be a ListOrderedMap but due to the fact that the constructor
is not visible and decorate only returns the base interface OrderedMap an unnecessary cast
is required.
>  ListOrderedMap map = (ListOrderedMap)ListOrderedMap.decorate(new MyMap());
> As the decorate method is static and not part of any interface it should be fine to return
the real type instead of the base. Otherwise I'd suggest to make the constructor visible.
From the API POV It is not really understandable why this
>  ListOrderedMap map = new ListOrderedMap();
> is fine and creates a HashMap under the hood while this
>  ListOrderedMap map = new ListOrderedMap(new MyMap()));
> is not ok.

This message is automatically generated by JIRA.
For more information on JIRA, see:

View raw message