Man1 - jdeps-openjdk17.1
Table of Contents
 
  
NAME
jdeps - launch the Java class dependency analyzer
SYNOPSIS
jdeps [/options/] path …
- options
- Command-line options. For detailed descriptions of the
options that can be used, see
- Possible Options
- Module Dependence Analysis Options
- Options to Filter Dependences
- Options to Filter Classes to be Analyzed
 
- path
- A pathname to the .classfile, directory, or JAR file to analyze.
DESCRIPTION
The jdeps command shows the package-level or class-level
dependencies of Java class files. The input class can be a path name to
a .class file, a directory, a JAR file, or it can be a fully
qualified class name to analyze all class files. The options determine
the output. By default, the jdeps command writes the dependencies to
the system output. The command can generate the dependencies in DOT
language (see the -dotoutput option).
POSSIBLE OPTIONS
- *=-?= or -hor =–help=*
- Prints the help message.
- *=-dotoutput= dir or --dot-output/dir/*
- Specifies the
destination directory for DOT file output. If this option is
specified, then the jdeps=*command generates one *.dot= file for each analyzed archive namedarchive-file-name.dotthat lists the dependencies, and also a summary file namedsummary.dotthat lists the dependencies among the archive files.
- *=-s= or =-summary=*
- Prints a dependency summary only.
- *=-v= or =-verbose=*
- Prints all class-level dependencies. This is equivalent to - -verbose:class -filter:none
- -verbose:package
- Prints package-level dependencies excluding, by default, dependences within the same package.
- -verbose:class
- Prints class-level dependencies excluding, by default, dependencies within the same archive.
- *=-apionly= or =–api-only=*
- Restricts the analysis to APIs,
for example, dependences from the signature of publicandprotectedmembers of public classes including field type, method parameter types, returned type, and checked exception types.
- *=-jdkinternals= or =–jdk-internals=*
- Finds class-level dependences in the JDK internal APIs. By default, this option analyzes all classes specified in the - --classpathoption and input files unless you specified the- -includeoption. You can’t use this option with the- -p,- -e, and- -soptions.- Warning: The JDK internal APIs are inaccessible. 
- (no term)
- *=-cp= path, -classpathpath, or--class-path/path/* :: Specifies where to find class files.
- *=–module-path= /module-path/*
- Specifies the module path.
- *=–upgrade-module-path= /module-path/*
- Specifies the upgrade module path.
- *=–system= /java-home/*
- Specifies an alternate system module path.
- *=–add-modules= module-name[*=,=* module-name…]*
- Adds modules to the root set for analysis.
- *=–multi-release= /version/*
- Specifies the version when processing multi-release JAR files. version should be an integer >=9 or base.
- *=-q= or =-quiet=*
- Doesn’t show missing dependencies from
-generate-module-infooutput.
- *=-version= or =–version=*
- Prints version information.
MODULE DEPENDENCE ANALYSIS OPTIONS
- *=-m= module-name or --module/module-name/*
- Specifies the root module for analysis.
- *=–generate-module-info= /dir/*
- Generates module-info.javaunder the specified directory. The specified JAR files will be analyzed. This option cannot be used with--dot-outputor--class-pathoptions. Use the--generate-open-moduleoption for open modules.
- *=–generate-open-module= /dir/*
- Generates module-info.javafor the specified JAR files under the specified directory as open modules. This option cannot be used with the--dot-outputor--class-pathoptions.
- *=–check= module-name [*=,=* module-name…]*
- Analyzes the dependence of the specified modules. It prints the module descriptor, the resulting module dependences after analysis and the graph after transition reduction. It also identifies any unused qualified exports.
- --list-deps
- Lists the module dependences and also the package
names of JDK internal APIs (if referenced). This option transitively
analyzes libraries on class path and module path if referenced. Use
--no-recursiveoption for non-transitive dependency analysis.
- --list-reduced-deps
- Same as --list-depswithout listing the implied reads edges from the module graph. If module M1 reads M2, and M2 requires transitive on M3, then M1 reading M3 is implied and is not shown in the graph.
- --print-module-deps
- Same as --list-reduced-depswith printing a comma-separated list of module dependences. The output can be used byjlink --add-modulesto create a custom image that contains those modules and their transitive dependences.
- --ignore-missing-deps
- Ignore missing dependences.
OPTIONS TO FILTER DEPENDENCES
- *=-p= pkg_name, -packagepkg_name, or--package/pkg_name/* :: Finds dependences matching the specified package name. You can specify this option multiple times for different packages. The-pand-eoptions are mutually exclusive.
- Finds
dependences matching the specified pattern. The -pand-eoptions are mutually exclusive.
- Finds dependences matching the given
module name (may be given multiple times). The --package,--regex, and--requireoptions are mutually exclusive.
- Filters dependences matching the given pattern. If give multiple times, the last one will be selected.
- Filters dependences within the same package. This is the default.
- Filters dependences within the same archive.
- Filters dependences within the same module.
- No -filter:packageand-filter:archivefiltering. Filtering specified via the-filteroption still applies.
- Finds missing dependences. This option cannot
be used with -p,-eand-soptions.
OPTIONS TO FILTER CLASSES TO BE ANALYZED
- *=-include= /regex/*
- Restricts analysis to the classes matching
pattern. This option filters the list of classes to be analyzed. It
can be used together with -pand-e, which apply the pattern to the dependencies.
- *=-P= or =-profile=*
- Shows the profile containing a package.
- *=-R= or =–recursive=*
- Recursively traverses all run-time
dependences. The -Roption implies-filter:none. If-p,-e, or-foptions are specified, only the matching dependences are analyzed.
- --no-recursive
- Do not recursively traverse dependences.
- *=-I= or =–inverse=*
- Analyzes the dependences per other given
options and then finds all artifacts that directly and indirectly
depend on the matching nodes. This is equivalent to the inverse of the
compile-time view analysis and the print dependency summary. This
option must be used with the --require,--package, or--regexoptions.
- --compile-time
- Analyzes the compile-time view of transitive
dependencies, such as the compile-time view of the -Roption. Analyzes the dependences per other specified options. If a dependency is found from a directory, a JAR file or a module, all classes in that containing archive are analyzed.
EXAMPLE OF ANALYZING DEPENDENCIES
The following example demonstrates analyzing the dependencies of the
Notepad.jar file.
Linux and OS X:
  $ jdeps demo/jfc/Notepad/Notepad.jar
  Notepad.jar -> java.base
  Notepad.jar -> java.desktop
  Notepad.jar -> java.logging
     <unnamed> (Notepad.jar)
        -> java.awt
        -> java.awt.event
        -> java.beans
        -> java.io
        -> java.lang
        -> java.net
        -> java.util
        -> java.util.logging
        -> javax.swing
        -> javax.swing.border
        -> javax.swing.event
        -> javax.swing.text
        -> javax.swing.tree
        -> javax.swing.undo
Windows:
  C:\Java\jdk1.9.0>jdeps demo\jfc\Notepad\Notepad.jar
  Notepad.jar -> java.base
  Notepad.jar -> java.desktop
  Notepad.jar -> java.logging
     <unnamed> (Notepad.jar)
        -> java.awt
        -> java.awt.event
        -> java.beans
        -> java.io
        -> java.lang
        -> java.net
        -> java.util
        -> java.util.logging
        -> javax.swing
        -> javax.swing.border
        -> javax.swing.event
        -> javax.swing.text
        -> javax.swing.tree
        -> javax.swing.undo
EXAMPLE USING THE –INVERSE OPTION
$ jdeps --inverse --require java.xml.bind Inverse transitive dependences on [java.xml.bind] java.xml.bind <- java.se.ee java.xml.bind <- jdk.xml.ws java.xml.bind <- java.xml.ws <- java.se.ee java.xml.bind <- java.xml.ws <- jdk.xml.ws java.xml.bind <- jdk.xml.bind <- jdk.xml.ws