jarjava-9java-modulejdeps

creating module-info for automatic modules with jdeps in java 9


I have 3 jar of jackson library

  1. jackson-core-2.8.10.jar
  2. jackson-annotations-2.8.0.jar
  3. jackson-databind-2.8.10.jar

I created module-info.java for both core and annotation successfully and converted them to Named maodule using jdeps.

for databind , I tried following command:

jdeps --generate-module-info . --module-path %JAVA_HOME%\jomds;jackson.core;jackson.annotations existingmods\jackson-databind-2.8.10.jar

Now following error is occuring :

Missing dependence: .\jackson.databind\module-info.java not generated
Error: missing dependencies
   com.fasterxml.jackson.databind.AnnotationIntrospector -> com.fasterxml.jackson.annotation.JsonCreator       not found
   com.fasterxml.jackson.databind.AnnotationIntrospector -> com.fasterxml.jackson.annotation.JsonCreator$Mode  not found
   com.fasterxml.jackson.databind.AnnotationIntrospector -> com.fasterxml.jackson.annotation.JsonFormat        not found
   com.fasterxml.jackson.databind.AnnotationIntrospector -> com.fasterxml.jackson.annotation.JsonFormat$Value  not found
   com.fasterxml.jackson.databind.AnnotationIntrospector -> com.fasterxml.jackson.annotation.JsonIgnoreProperties not found
   com.fasterxml.jackson.databind.AnnotationIntrospector -> com.fasterxml.jackson.annotation.JsonIgnoreProperties$Value not found.

How can I generate module-info.java for jackson-databind ?


Solution

  • The short answer is that, yes, you'll have to convert the libraries to explicit modules.

    The jlink tool is intended to provide a trimmed binary image that has only the required modules. The issue is that automatic modules have access to the classpath (aka the unnamed module) which can read all JDK modules. So nothing would be trimmed.

    This thread states this as well, with a link to a YouTube video.

    This example converts commons-lang3-3.5.jar to an explict module for a jlink demo.

    Edit: to be more specific, here is an example script that converts, in order, jackson-core, jackson-annotations, and jackson-databind legacy jars to modular jars.

    The idea is:

    The trick is that modular jars with dependencies will require those dependencies as command-line parameters. For example, here is jackson-databind (abstracted somewhat):

    # here, jackson-core and jackson-annotations have been built
    # jackson-databind 
    
    jdeps --module-path $ROOT_DIR/modules \
    --add-modules jackson.annotations,jackson.core \
    --generate-module-info work $JACKSON_DATABIND_JAR
    
    javac --module-path $ROOT_DIR/modules \
    --add-modules jackson.annotations,jackson.core \
    -d $ROOT_DIR/classes module-info.java