8000354: (props) Properties.storeToXML/loadFromXML need to allow for alternative implementations

Alan Bateman Alan.Bateman at oracle.com
Fri Oct 5 13:41:14 UTC 2012


Properties defines the loadFromXML and storeToXML methods for 
loading/storing properties in XML format. These methods are problematic 
for our efforts to modularize the JDK because of the dependency on XML. 
They are also problematic for the Compact Profiles proposal [1] as it is 
unlikely that JAXP will be present in the smallest profile.

As the XML parsing needs of Properties is relatively simple we are 
thinking about including a small footprint parser that is sufficient for 
its needs. Joe Wang is looking this. In preparation for this we need to 
decouple Properties from the parser API that it uses and this is what 
the proposal here is about.

The webrev with the proposed changes is here:

http://cr.openjdk.java.net/~alanb/8000354/webrev/

Basically it introduces a JDK internal provider interface to which the 
loadFromXML and storeToXML methods delegate. The existing code that uses 
JAXP is moved into a provider implementation and will be used when 
present. When not present then the intention is that it will fallback to 
a default implementation that is the small footprint provider that Joe 
will add later. This approach ensures that we maintain compatibility (it 
remains to be seen whether we will have to deal with a few subtle issues 
when using the tiny parser). For test purposes there is a system 
property for overriding the provider, this is also why the system class 
loader is used as the initiating loader.

I should explain that when I say  "JDK internal provider interface" then 
the service type is in sun.util.spi for now. Maybe in the future it may 
be necessary to define a standard provider interface but it is not 
needed at this time (in addition it would require getting the security 
right to do that).

Thanks,

Alan.

[1] http://openjdk.java.net/jeps/161



More information about the core-libs-dev mailing list