-
Notifications
You must be signed in to change notification settings - Fork 114
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
Uses shaded eclipse dependencies in Gradle plugin #148
Comments
Thanks, @magJ. I wasn't aware that you were overriding the version of the Eclipse runtime that's used. I'm pretty sure that makes this a duplicate of #139. Let's keep it open for now though as I'd like to learn more about the problems caused by "all sorts of classes and junk that conflict with other plugins used in gradle". Can you expand on that a little bit please? What sort of problems and conflicts have you seen? |
@wilkinsona I can't provide you example code at the moment, but the problem that I ran into was with a plugin that used a jersey client.
Seems like it could go on a diet. |
Unfortunately, I don't think that's possible. Those classes come from the various jars files in Eclipse upon which The lack of class loader isolation between plugins is a long-standing weakness of Gradle. There was talk of it being addressed a few years ago but, as far as I know, other higher priority changes took priority and it has yet to happen. If clashes become regularly problematic (this is the first time we have heard of one) it may be that we have to implement our own isolation. |
The updates sample works with the latest version when jdt 3.19.0 is used. Unfortuantely 3.18.0 doesn't work. |
I've updated the Gradle plugin to use shaded dependencies which should stop the classpath clashes. |
Attempt to fix CI issues caused by shading. See gh-148
Attempt to fix CI issues caused by shading. See gh-148
As mentioned in #139 (comment)
When running the gradle plugin using versions of
org.eclipse.jdt:org.eclipse.jdt.core
above3.17.0
, formatter tasks(iecheckFormat*
orformat
) fail with a Java heap space issue.Exact cause is unknown, but it appears as though the loop in
io.spring.javaformat.formatter.eclipse.DefaultCodeFormatter#tokenizeSource
never encounters it's break condition.Demo project that produces the issue: https://github.com/magJ/spring-format-issue
Now using the plugin, and replacing the shaded runtime jar with the real eclipse dependency, is not documented anywhere, so I anticipate this being closed as an unsupported use case.
data:image/s3,"s3://crabby-images/7177f/7177f9c21b8facf0b27ddd98b1f8866699efd99a" alt="image"
I could raise the problems with using the shaded runtime jar as a separate issue if desired, but in short, it contains all sorts of classes and junk that conflict with other plugins used in gradle.
The text was updated successfully, but these errors were encountered: