Skip to content
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

[jdk11] problem with dependencies #3303

Open
firm1 opened this issue Jul 20, 2020 · 6 comments
Open

[jdk11] problem with dependencies #3303

firm1 opened this issue Jul 20, 2020 · 6 comments

Comments

@firm1
Copy link

firm1 commented Jul 20, 2020

Hello,

I have an dependency problem with your packages.

My gradle script look like :

dependencies {
...
compile group: 'org.languagetool', name: 'language-fr', version: '5.0'
}

When i run my code with this, i have some problem like

error: the unnamed module reads package org.languagetool.language from both language.fr and languagetool.core

Can you have an example of java project wich use jdk >= 9 with maven or gradle ?

@chbriem
Copy link

chbriem commented Sep 7, 2021

The code seems not to be compatible with Java 9+, because of split packages.

I'd suggest to at least add a hint to the documentation. The sentence

LanguageTool requires Java 8 or later.

is clearly wrong and should be "LanguageTool works with Java 8 only. Later versions are not yet fully supported."

@miurahr
Copy link
Contributor

miurahr commented Sep 10, 2023

For SEO, I'd like to leave a precise comment to the issue.

More clearly said, LanguageTool works with Java 8 and later WITHOUT Java Platform Module System (JPMS) support.

All the project with configured with JPMS will get java.lang.module.ResolutionException error when booting your application, then detect package duplication and show a cause that LT languages are share the same package that is bad habit in modern Java.

It may be a possible solution for the application with JPMS that you may want to "unsplit" all the LanguageTool's language jars into a single custom module.

Because LanguageTool project don't take any action to solve the issue as in Sept. 2023, It is not easy to use LanguageTool in a project with JPMS enabled.

@miurahr
Copy link
Contributor

miurahr commented Oct 8, 2023

Similar issue is reported in languagetool forum. https://forum.languagetool.org/t/java-11-dependencies-requirements/6155

@LavishKothari
Copy link

Do we have any timelines around when this issue will be fixed?

Given #9406 is a breaking change, and if we don't want to go ahead with this, can Languagetool export a fat jar (languagetool-core and language-en) so that there is a workaround for users for the interim time.

@miurahr
Copy link
Contributor

miurahr commented Jul 26, 2024

Do we have any timelines around when this issue will be fixed?

Given #9406 is a breaking change, and if we don't want to go ahead with this, can Languagetool export a fat jar (languagetool-core and language-en) so that there is a workaround for users for the interim time.

#9406 provide a compatibility module that keep users who implement JAVA8 base client to used as same as before.
It is for user who don't want to keep a legacy code.
It also provide a breaking change with the legacy code to be JPMS compatible. Because modern project does not use a direct instantiation of language modules, but use recommended indirect way, that will be not broken with the change.

@miurahr
Copy link
Contributor

miurahr commented Dec 19, 2024

#9406 provide a compatibility module that keep users who implement JAVA8 base client to used as same as before. It is for user who don't want to keep a legacy code. It also provide a breaking change with the legacy code to be JPMS compatible. Because modern project does not use a direct instantiation of language modules, but use recommended indirect way, that will be not broken with the change.

There is an idea to provide all the compatibility classes with core library.
It allows users upgrade without changing dependency configuration.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

5 participants