Thank you for your suggestion. jansi should be placed in the boot layer, because it is also used by log4j2, that also should be in the boot layer.
I think (I may be wrong, because I am not a JPMS guru like jigsaw team members) the problem arises due to two serious constraints: 1. we don't have access to the boot layer controller and we received a categorical refusal to grant access to it. 2. qualified opens/exports doesn't work to child layers. For example, I can't even open an issue in jansi project to open internal package to jline because it gives nothing in this situation. Best regards,CR On 1/31/25 17:30, David Lloyd wrote:
AFAIK it cannot be done with `jansi` in your boot layer. One solution would be to put it into a child layer, which will allow you to access the `Controller` for it, which you can then use to add the export manually after defining the `jline3` module in its sub-layer. Otherwise, `jansi` would have to cooperatively call `Module.addExports` for your module, which seems unlikely to me. On Fri, Jan 31, 2025 at 7:19 AM Code Ranger <coderanger2...@outlook.com> wrote: Hello all. I have a boot layer with `org.fusesource.jansi` module a child layer with jline3 module. Jline3 wants to use jansi: Caused by: java.lang.IllegalAccessError: class org.jline.terminal.impl.jansi.JansiTerminalProvider (in module org.jline) cannot access class org.fusesource.jansi.internal.Kernel32 (in module org.fusesource.jansi) because module org.fusesource.jansi does not export org.fusesource.jansi.internal to module org.jline at org.jline@3.28.0/org.jline.terminal.impl.jansi.JansiTerminalProvider.verifyAtLeast(JansiTerminalProvider.java:85) ~[jline-3.28.0.jar:?] at org.jline@3.28.0/org.jline.terminal.impl.jansi.JansiTerminalProvider.<init>(JansiTerminalProvider.java:93) ~[jline-3.28.0.jar:?] at java.base/jdk.internal.reflect.DirectConstructorHandleAccessor.newInstance(DirectConstructorHandleAccessor.java:62) ~[?:?] at java.base/java.lang.reflect.Constructor.newInstanceWithCaller(Constructor.java:502) ~[?:?] at java.base/java.lang.reflect.Constructor.newInstance(Constructor.java:486) ~[?:?] at org.jline@3.28.0/org.jline.terminal.spi.TerminalProvider.load(TerminalProvider.java:69) ~[jline-3.28.0.jar:?] If I do --add-exports org.fusesource.jansi/org.fusesource.jansi.internal=org.jline \ I get WARNING: Unknown module: org.jline specified to --add-exports (as I was already told if a module is not the boot layer it is just ignored) if I do --add-exports org.fusesource.jansi/org.fusesource.jansi.internal=ALL-UNNAMED \ I get the same exception. Could anyone say how to fix it? Best regards, CR -- - DML • he/him