RFR: JDK-8189611: JarFile versioned stream and real name support

Alan Bateman Alan.Bateman at oracle.com
Mon Nov 20 14:42:03 UTC 2017



On 17/11/2017 16:53, Xueming Shen wrote:
> On 11/17/17, 3:35 AM, Alan Bateman wrote:
>> :
>>
>> 1. getRealName is very welcome but I think it should be a no-arg 
>> method on JarEntry, not JarFile. That would make it easier to use and 
>> also avoids the temptation to call JarFile.getRealName with an entry 
>> in a different JAR file.
>>
>
> I was considering to put it into JarEntry. The only concern is that 
> all mr jarfile related stuff
> are in JarFile, it's kinda easy/convenient to refer to the concept "if 
> multi-release is..." in
> JarFile than JarEntry, especially considering mr jarfile normally 
> should only be interested/
> used by limited group of developer, it might be better to simply put 
> it near those mr related
> methods. But I don't have a strong opinion about it. I can move it 
> into JarEntry, if it's desired.
The existing JarFile methods yield objects or streams of JarEntry. It 
would be a bit inconsistent to introduce a method that returns an entry 
name as a String. In the opposite corner, JarEntry defines getName and 
it shouldn't be a surprise to have it define getRealName too.

The other awkward issue with getRealName(JarEntry) is that it has to 
deal with the case that someone calls it with a JarEntry from a 
different JarFile. And like getInputStream(JarEntry), it needs to be 
concerned with a closed JarFile.

So I think on balance JarEntry::getRealName is better. It does mean that 
the javadoc needs to reference the MR text in JarFile.

-Alan.


More information about the core-libs-dev mailing list