[regression] Internal utility classes of core leak into plugin realm --------------------------------------------------------------------
Key: MNG-4273 URL: http://jira.codehaus.org/browse/MNG-4273 Project: Maven 2 Issue Type: Bug Components: Class Loading, Plugins and Lifecycle Affects Versions: 3.0-alpha-2 Reporter: Benjamin Bentmann The current class loader hierarchy of 3.x looks like: - {{plexus.core}} as root realm with the contents of {{lib/*.jar}} - {{plugin: g:a:v}} as child of {{plexus.core}} This basically makes {{lib/*.jar}} completely available to the plugin realm, including classes that we don't want/need to share with plugins because they assist the implementation of the core but not the interop between core and plugin. The current design gives rise to errors like the linkage error reported in [MNGECLIPSE-1487|https://issues.sonatype.org/browse/MNGECLIPSE-1487]: - a plugin creates a custom URL class loader (with parent delegation) that contains project dependencies, among others xercesImpl, on top of its plugin realm - the plugin sets the new class loader as TCCL and invokes a tool that wants to employ a SAX parser - the parser factory of the JRE will search the TCCL for a suitable SAX parser and will discover xercesImpl in the TCCL - loading of the xerces parser triggers loading of {{XML11Configuration}} from the TCCL which inherits from {{ParserConfigurationSettings}} - due to parent delegation, the {{ParserConfigurationSettings}} will however be loaded from {{plexus.core}} which holds xercesMinimal - xercesMinimal provides an incompatbile version of {{ParserConfigurationSettings}}, which finally crashes the plugin with a linkage error -- This message is automatically generated by JIRA. - If you think it was sent incorrectly contact one of the administrators: http://jira.codehaus.org/secure/Administrators.jspa - For more information on JIRA, see: http://www.atlassian.com/software/jira