-
Notifications
You must be signed in to change notification settings - Fork 139
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Compilation for JavaSE-1.8 does not guarantee Java 8 class files #2605
Comments
I have investigated very similar issue just yesterday. |
Using 'future' API seems pretty suspect to me, although, to use an analogy, I can just see that a Shakespearean sonnet about Artificial Intelligence is not impossible. However release enabled should be a strongly encouraged default. Allowing the prefs to differ from the UI is a recipe for disaster since the prefs is regularly improved whenever the UI page is accessed. |
When you select JavaSE-1.8 this is meant to refer to an actual JDK 1.8. That JDK does not support The point to observe: you should not "lie" when associating actual JDKs to (abstract) execution environments. If you compile against JDK 17 say JavaSE-17 and |
I do not see a bug here, closing. |
Not a bug, right. @ewillink to see the desired magic at work, configure a workspace with only a new JRE, e.g., 22, and then create a project compiling against See the info at the bottom? The only thing left to be desired: when migrating an existing project from 1.5 to 1.8 or such, while only a newer JRE is installed, the
I don't think this is worth implementing a specific wizard, but "contributions are welcome" ... |
@iloveeclipse surely you should allow more than 7 minutes for a response before arbitrary closure? @stephan-herrmann when I select JavaSE-1.8 i expect the result to suit all JavaSE-1.8 executions. I do not have the option of using JavaSE-1.8 since the Eclipse IDE now mandates Java 17 which does support --release so I expect it to be used. @stephan-herrmann The image you show seems perfect. My use of 4.32 with jdk-17.0.8 as default and jdk-11.0.19 and jdk-1.8.0_371 and jdk-1.5.0_22 also installed is almost the same as your image: BUT the greyed out --release is not selected and there is no info that it is selected. Your suggestion of disabling, changing, reverting doesn't work for; the --release remains greyed out. It is only class files built 'by Tycho' that are problematic, so perhaps the IDE is getting it right, but JDT is failing to communicate the --release to the Tycho compilation or the Tycho compilation is ignoring it. Whatever, somewhere there is a bug. I should not be having to spend a couple days investigating why I get a strange CNFE crash in my (jdk11) compatibility tests. When I specify JavaSE-1.8, I expect JavaSE-1.8 compliance or a diagnostic explaining why I'm not getting it. |
You do have the option to configure a 1.8 JRE under "Installed JREs". If you do so, it will be used for your "JavaSE-1.8" project and all will be well.
In that configuration "JavaSE-1.8" selects jdk-1.8.0_371 and hence
Also tycho should not need
Perhaps. Provide a sample project where JDT violates your settings, and I will look at it. |
I have a JDK 8 in toolchains.xml, but globally the Eclipse IDE enforces at least JDK 11 and maybe even JDK 17. So I presume that a per-plugin toolchain setting override could be required to use the JDK 8. But since I use auto-poms for regular plugins, I don't want to have to introduce custom poms. Perhaps the bug is that the auto-pom fails to auto-toolchain. |
I hope you see, that there is too much "maven" / "tycho" and too much "perhaps" involved, for anyone in JDT to take action. The folks at tycho and / or m2e might know more. |
Perhaps, but the org.eclipse.jdt.core.compiler.release=disabled contrary to your image seems like a problem that clearly occurs at the JDT level. |
Did I ever mention that precise reproducible steps might help in our communication? 😄 |
Absolutely. I often insist on repros from my users. But producing a small repro can be very time consuming, sometimes insightful, sometimes a waste of time. I therefore advocate a preliminary discussion in case it is a recognisable problem. org.eclipse.jdt.core.compiler.release=disabled contrary to your image seems like a clear problem; perhaps not in the IDE because perhaps the IDE uses Java 8; perhaps in Tycho because the need for 100% Java 8 compliance has not been propagated. OCL commit 0a5c414abace6489afdbe65acfc3cbd63ba73870, 2 ahead of master refactored a routine to avoid a Constable local variable. a9c8a4c657302d9cb8a3f07aabdb32c1f668af77 is therefore a repro; ok in IDE, bad in the 'Build OCL DIstribution - nightly" m2e launch. The handleProblem method in plugins/org.eclipse.ocl/src/org/eclipse/ocl/lpg/AbstractProblemHandler.java hosts the problematic ?: that gives a bad Constable reference. |
in my book this doesn't qualify as "steps for reproduction".
I feel that further discussion is also a waste of time. |
https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/issues/4735 describes some pain after upgrading from Java 5 to Java 8 BREE. The problem was eventually diagnosed to a reference to the
@since Java 12
java.lang.const.Constable in a Java 8 class file.https://stackoverflow.com/questions/43102787/what-is-the-release-flag-in-the-java-9-compiler is helpful identifying -source, -target and --release as necessary to ensure Java 8 validity.
Problem: the JDT compiler preference page allows selection of compliance with the JavaSE-1.8 execution environment. This appears to automatically impose (grey-out) -source and -target 1.8; good. But it also greys out --release and imposes org.eclipse.jdt.core.compiler.release=disabled; bad.
Surely JavaSE-1.8 shoiuld impose org.eclipse.jdt.core.compiler.release=enabled or at least allow the user to choose?
The text was updated successfully, but these errors were encountered: