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

Reply via email to