On 4/15/2020 12:00 AM, Jochen Theodorou wrote:
On 14.04.20 19:38, Alex Buckley wrote:
[...]
It's fine for
Library1 to require SharedApi, and for Library2 to require
SharedApiImpl, but if the exported packages overlap, then it's not fine
for Project to require, indirectly, both SharedApi (via Library1) and
SharedApiImpl (via Library2). That is, SharedApi and SharedApiImpl are
not composable.

And what do you do when you are in that situation?

If you had put them both on the classpath in JDK 8, then
you would have had a broken system. If you want to compose an
application that includes both, then one of them has to change.
There is no need to speak of "transitive" modules because `requires
transitive` has not entered the picture.

Without the module system I can just exclude one and be fine. With
module system I get into a split package problem adn have not found a
real solution yet

In the JDK 8 world: If SharedApi and SharedApiImpl have different names, then (as you implied to Remi) Maven is going to treat them independently and put both on the classpath. Yes, you can realize that their content overlaps and exclude one of them in your POM, but *every* *single* *user* has to travel that road independently! If a user doesn't realize, and doesn't exclude, then their classpath has split packages and their application is broken. I think it's outrageous that the developers of SharedApi and SharedApiImpl imposed this tax on *every* *single* *user* and no-one held them to account.

Post JDK 8: Only when SharedApi and SharedApiImpl are modularized does the presence of overlapping exports become clear, and prevent an application from being composed unsafely.

There is nothing you can do in the module-info.java of your application to express that its module graph indirectly requires the uncomposable modules M,N,O and that any `requires M` and `requires N` clauses should be overridden with `requires O`. This would be a maintenance nightmare. Mail their developers and tell them what they've done. Every library including its own copy of a standard API is a bug, not a feature.

(If a library is explicitly written to be loaded in its own class loader, such as in the OSGi environment, then things are different: private copies of APIs are OK, up to a point. However, the libraries you are using are plainly from the JDK 8 classpath era and have been lightly modularized -- enough for each vendor to let their module be required and jlinked, but not enough to address the bigger architectural issue of reuse / composability.)

Alex

Reply via email to