trying jigsaw-ea-95 jlink

Martin Balin martin.balin at oracle.com
Mon Dec 21 08:58:09 UTC 2015


Thanks' for explanation.
Would not it make a sense to extend java.util.jar.Attributes.Name class 
to support ConcealedPackages new optional attribute?

Martin

On 16.12.2015 11:19, Alan Bateman wrote:
> On 16/12/2015 09:27, Martin Balin wrote:
>> I've encountered this problem with jlink as well. The scenario was 
>> different. I used modular jar files produced by NetBeans with jigsaw 
>> build. NetBeans uses Ant jar task to create jar files. At this moment 
>> we run NB on top of JDK8 and Jigsaw is referenced as Project Java 
>> platform. Therefore NetBeans produces jar file using jar task based 
>> on JDK8 which is not compatible with JDK9 jlink.
>>
>> I found that I can run these NB produced modular jar files on Jigsaw 
>> e.g.
>> > "java -mp.... -m <module_name/fully_qualified_main_class>"
>>
>> But I cannot run such modular jigsaw app when packaged by jlink. Even 
>> specifying Main class does not help. It needs to be packaged by jar 
>> utility from jigsaw in order to be runnable in jlink.
>>
>> Is this going to be defined somewhere? E.g. Jigsaw jar utility 
>> specification and how it changed from JDK8 jar.
>
> One we fix this issue then it should resolve this case too and there 
> should be no issue creating the JAR files with older versions of the 
> jar tool or any zip tool.
>
> As to what is going on? The set of exported packages are in the Module 
> class file attribute. There may be other non-exported packages and as 
> an optimization to avoid scanning the contents of the JAR, then this 
> set of packages can be stored in the optional ConcealedPackages class 
> file attribute. The jar and jmod tools add or update this attribute, 
> older versions of the jar tool or zip programs don't know anything 
> about it. When the attribute is not present then the contents of the 
> JAR file will be scanned or the file system will be scanned in the 
> case of an exploded module.
>
> There is a missing piece when we get to jlink and the run-time images. 
> The code that reconstitutes the set of modules descriptors in the 
> run-time image assumes the ConcealedPackages attribute is present. 
> This works great when the modules are in JMOD format or generated with 
> the updated jar tool but doesn't work when the modules don't have this 
> attribute. The original intention was it be generated at link-time. 
> We've since moved on much further to generate code at link time to 
> speed up the reconstitution of the module descriptors.  I initially 
> thought `jlink --gen-installed-modules off` would be a workaround for 
> Sebastian but there is a bit more to it. So I think the "TODO" needs a 
> priority boost.
>
> -Alan



More information about the jigsaw-dev mailing list