Code Review Request for 6578042

Darryl Mocek darryl.mocek at oracle.com
Tue Nov 15 19:51:00 UTC 2011


I've modified the fix per feedback (thanks all).  System.clearProperty 
now attempts to get the property with the specified key.  If there is 
such a property, and the value is a String, remove the property and 
return the value removed, otherwise return null (if it is null) or throw 
CCE (if it's not null and is not a String...do not remove the property 
here).  Webrev can be found here:

http://cr.openjdk.java.net/~sherman/darryl/6578042/webrev

Darryl


On 11/12/2011 04:14 AM, Alan Bateman wrote:
> On 11/11/2011 19:37, Darryl Mocek wrote:
>> Returning null if the value is not a String gives the impression that 
>> there was no property with that key when the property may have been 
>> there and may in fact have been removed. 
> That's a fair point and probably enough to conclude that this approach 
> should be dismissed.
>
> The toString approach is inconsistent so I think this brings us back 
> to the original suggestion which is to specify that CCE is thrown (as 
> it always has) but without side effects (meaning it doesn't remove the 
> property). I think this is the best we can do with this broken API.
>
> :
>>
>> I would prefer it if Properties didn't allow non-String keys and 
>> values at all since they're supposed to be Strings (by API 
>> implication) and that Properties not extend Hashtable or extends 
>> Hashtable<String, String>, but I digress.
> Properties goes back to JDK1.0 and has a warning in its javadoc for 
> many years to discourage inserting keys or values that are not 
> Strings. I'm not sure whether we can do much about it now without 
> risking compatibility issues.
>
> -Alan.



More information about the core-libs-dev mailing list