RFR: JDK-8189094: Change required boot jdk to JDK 9
Alan Bateman
Alan.Bateman at oracle.com
Mon Oct 16 17:18:19 UTC 2017
On 16/10/2017 16:41, Martin Buchholz wrote:
> The difficulties encountered trying to run langtools10 in a jdk9 suggests
> that the jdk9 module model is too restrictive. I've long lobbied for
> treating langtools as just another collection of ordinary programs that
> happen to be written in java and should not need special support from the
> host jdk.
>
> Many people will want to run modified langtools. Shouldn't replaceability
> of any module be one of the goals of the module system?
>
The module system already supports ways to replace/override a module
(via the upgrade module path and the --upgrade-module-path option) or
patch/augment a module to override or add classes/resources
(--patch-module).
At the same time, it supports the ability to tie a group of closely
connected modules with integrity hashes to prevent accidental mixing of
modules from different builds or releases.
The issue that Erik has been wrestling with is that a module can't be
both upgradeable and non-upgradable at the same time. If they
upgradeable then you risk someone creating a run-time image with
jdk.compiler and jdk.javadoc modules from different JDK releases - it's
not supportable of course. If you continue with them as non-upgradeable
modules then you need to do something special in the JDK build to
combine a boot JDK with newer versions of the modules and this is what
Erik is doing. There are a couple of ways to do that, like putting the
classes for these modules on the class path and limiting observability
with --limit-modules. The alternative is to put the code into modules
with new names, Erik's patch favors that approach.
-Alan.
More information about the build-dev
mailing list