|
GigaSpaces XAP 8.0 API | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object com.sun.jini.tool.ClassDep
public class ClassDep
Tool used to analyze a set of classes and determine on what other classes
they directly or indirectly depend. Typically this tool is used to
compute the necessary and sufficient set of classes to include in a JAR
file, for use in the class path of a client or service, or for use in the
codebase of a client or service. The tool starts with a set of "root"
classes and recursively computes a dependency graph, finding all of the
classes referenced directly by the root classes, finding all of the
classes referenced in turn by those classes, and so on, until no new
classes are found or until classes that are not of interest are
found. The normal output of the tool is a list of all of the classes in
the dependency graph. The output from this command can be used as input
to the jar
tool, to create a JAR file containing precisely
those classes.
The following items are discussed below:
java -jar install_dir/lib/classdep.jar -cp input_classpath processing_options output_options
where install_dir is the directory where the starter kit is installed. Note that the options for this tool can be specified in any order, and can be intermixed.
The -cp
class path value,
input_classpath,
is an argument to the ClassDep
tool itself and should
include all of the classes that might need to be included in the
dependency analysis. Typically this will include all of your application
classes, classes from the starter kit, and any other classes on which
your classes might depend. It is safe to include more classes than are
actually necessary (since the purpose of this tool is, after all, to
determine which subset of these classes is actually necessary), but it is
not necessary to include any classes that are part of the Java 2 SDK.
The class path should be in the form of a list of directories or JAR
files, delimited by a colon (":") on UNIX platforms and a semi-colon
(";") on Microsoft Windows platforms. The order of locations in the path
does not matter. If you use JAR files, any Class-Path
manifest entries in those JAR files are ignored, so you must include the
values of those manifest entries explicitly in the path, or errors may
result. For example, if you include jini-ext.jar
then you
should explicitly include jini-core.jar
as well, because
jini-core.jar
is in the Class-Path
manifest
entry of jini-ext.jar
.
In general, you only need to specify concrete classes as roots, not
interface types. When analyzing classes for the class path of an
application, you typically need to include the top-level class (the one
with the main
method). When analyzing classes for the
codebase of a service, you typically need to include the top-level proxy
classes used by the service, any trust verifier classes for those
proxies, and any custom entry classes used by the service for lookup
service attributes. Also when analyzing classes for the codebase of a
service, if the service's proxy can return leases, registration objects,
or other proxies, or if your service generates events, and if those
objects are only referenced by interface type in the top-level proxy, not
by concrete class, then you also need to include the concrete classes of
those other objects. In all cases, you typically need to include any stub
classes that you generated with the rmic
tool.
The -prune
option can be used to exclude particular subtrees
from the set of roots.
-prune
package-prefix
-prune
is a package
namespace (delimited by "."), not a directory.
The -skip
option (described further below) can be used to
exclude specific classes from the set of roots.
Starting with the root classes, a dependency graph is constructed by examining the compiled class file for a class, finding all of the classes it references, and then in turn examining those classes. The extent of the graph is determined by which packages are defined to be "inside" the graph and which are defined to be "outside" the graph. If a referenced class is in a package that is defined to be outside the graph, that class is not included in the graph, and none of classes that it references are examined. All of the root classes must be in packages that are defined to be "inside" the graph.
The inside and outside packages are specified by using the following options. Each of these options may be specified zero or more times. Some variations are illustrated in the Examples section of this page.
-in
package-prefix
-out
or -skip
options. This
option can be specified zero or more times. If no -in
options are specified, the default is that all packages are considered to
be inside packages. Note that the argument to -in
is a
namespace, so none of its subpackages need to be specified as an argument
to -in
.
If you use this option, you will likely need to use it multiple
times. For example, if your application classes are in the
com.corp.foo
namespace, and you also use some classes in the
com.sun.jini
and net.jini
namespaces, then you
might specify:
-in com.corp.foo -in com.sun.jini -in net.jini
-out
package-prefix
-in
options,
then each -out
namespace should be a subspace of some
-in
namespace. Note that the argument to -out
is a namespace, so none of its subpackages need to be specified as an
argument to -out
.
If you use this option, you will likely need to use it multiple
times. For example, if you do not specify any -in
options,
then all packages are considered inside the graph, including packages
defined in the Java 2 SDK that you typically want to exclude, so you
might exclude them by specifying:
-out java -out javaxAs another example, if you have specified
-in com.corp.foo
but you don't want to include any of the classes in the
com.corp.foo.test
or com.corp.foo.qa
namespaces
in the dependency graph, then you would specify:
-out com.corp.foo.test -out com.corp.foo.qa
-skip
class
-outer
-edges
For example, you might exclude classes from the Java 2 SDK from the
dependency graph because you don't want to include them in your JAR file,
but you might be interested in knowing which classes from the Java 2 SDK
are referenced directly by the classes in your JAR file. The
-edges
option can be used to display this information.
-show
package-prefix
-show
options are specified, the default is that all classes
in the dependency graph are displayed (or all edge classes, if
-edges
is specified). Note that the argument to
-show
is a namespace, so none of its subpackages need to be
specified as an argument to -show
.
For example, to determine which classes from the Java 2 SDK your
application depends on, you might not specify any -in
options, but limit the output by specifying:
-show java -show javax
-hide
package-prefix
-show
options, then each -hide
namespace should
be a subspace of some -show
namespace. Note that the
argument to -hide
is a namespace, so none of its subpackages
need to be specified as an argument to -hide
.
For example, to determine which non-core classes from the
net.jini
namespace you use, you might specify:
-show net.jini -hide net.jini.core
-files
com\corp\foo\Bar.class
instead of
com.corp.foo.Bar
. This option should be used to generate
output suitable as input to the jar
tool.
For more information on the jar
tool, see:
-tell
class
classes
directory. Alternatively, if you have compiled from
the source code, substitute source/classes
for
classes
in the examples.)
The following example computes the classes required for a codebase JAR
file, starting with a smart proxy class and a stub class as roots, and
displays them in filename format. (A more complete example would include
additional roots for leases, registrations, events, and lookup service
attributes, and would exclude platform classes such as those in
jsk-platform.jar
.)
java -jar install_dir/lib/classdep.jar -cp install_dir/classes com.sun.jini.reggie.RegistrarProxy com.sun.jini.reggie.RegistrarImpl_Stub -in com.sun.jini -in net.jini -files
The following example computes the classes required for a classpath JAR
file, starting with all of the classes in a directory as roots, and
displays them in class name format. (A more complete example would exclude
platform classes such as those in jsk-platform.jar
.)
java -jar install_dir/lib/classdep.jar -cp install_dir/classes install_dir/classes/com/sun/jini/reggie -in com.sun.jini -in net.jini
The following example computes the com.sun.jini
classes used
by a service implementation, and displays the net.jini
classes that are immediately referenced by those classes.
java -jar install_dir/lib/classdep.jar -cp install_dir/classes com.sun.jini.reggie.RegistrarImpl -in com.sun.jini -edges -show net.jini
The following example computes all of the classes used by a service
implementation that are not part of the Java 2 SDK, and displays the
classes that directly reference the class java.awt.Image
.
java -jar install_dir/lib/classdep.jar -cp install_dir/classes com.sun.jini.reggie.RegistrarImpl -out java -out javax -tell java.awt.Image
The following example computes all of the classes to include in
jini-ext.jar
and displays them in filename format. Note
that both -out
and -prune
options are needed
for the net.jini.core
namespace; -out
to
exclude classes from the dependency graph, and -prune
to
prevent classes from being used as roots.
java -jar install_dir/lib/classdep.jar -cp install_dir/classes -in net.jini -out net.jini.core -in com.sun.jini install_dir/classes/net/jini -prune net.jini.core -files
Constructor Summary | |
---|---|
ClassDep()
No argument constructor. |
|
ClassDep(String[] cmdLine)
Constructor that takes command line arguments and fills in the appropriate fields. |
Method Summary | |
---|---|
void |
addClasses(String className)
Add an entry into the set of classes that dependencies are going to be computed on. |
void |
addHides(String packagePrefix)
Add an entry into the set of package prefixes that are to remain hidden from processing. |
void |
addInside(String packagePrefix)
Add an entry into the working set of package prefixes that will make up the working domain space. |
void |
addOutside(String packagePrefix)
Add an entry into the set of package prefixes that will bypassed during dependency checking. |
void |
addPrune(String packagePrefix)
Add an entry into the set of package prefixes that will be skipped as part of the dependency generation. |
void |
addRoots(String rootName)
Add an entry into the set of directories to look under for the classes that fall within the working domain space as defined by the intersection of the following sets: inside,outside,prune,show, and hide. |
void |
addShow(String packagePrefix)
Add an entry into the set of package prefixes that we want to display. |
void |
addSkip(String packagePrefix)
Add an entry into the set of classes that should be skipped during dependency generation. |
void |
addTells(String packagePrefix)
Add an entry in to the set of classes whose dependents that lie with the inside set are listed. |
String[] |
compute()
Method that takes the user provided switches that logically define the domain in which to look for dependencies. |
boolean |
getFiles()
If true classnames will be separated using File.separator, else it will use dots. |
String[] |
getResults()
Accessor method for the found dependencies. |
static void |
main(String[] args)
Command line interface for generating the list of classes that a set of classes depends upon. |
void |
setClassPath(String classpath)
Set the classpath to use for finding our class definitions. |
void |
setEdges(boolean edges)
Determines whether to include package references that lie outside the declared set of interest. |
void |
setFiles(boolean files)
Determines how to print out the fully qualified class names. |
void |
setupOptions(String[] args)
Convenience method for initializing an instance with specific command line arguments. |
static void |
usage()
Print out the usage for this utility. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public ClassDep()
public ClassDep(String[] cmdLine)
Method Detail |
---|
public String[] compute()
public static void usage()
public void setClassPath(String classpath)
public void setFiles(boolean files)
true
it will use
File.separator
, else .
's
will be used.
If not set the default is false
.
public void addHides(String packagePrefix)
public void addInside(String packagePrefix)
public void setEdges(boolean edges)
If true edges will be processed as well, else
they will be ignored. If not set the default
will be false
.
Note: These edge classes must included in the classpath for this utility.
public void addOutside(String packagePrefix)
public void addPrune(String packagePrefix)
public void addShow(String packagePrefix)
public void addSkip(String packagePrefix)
public void addTells(String packagePrefix)
public void addRoots(String rootName)
public void addClasses(String className)
public boolean getFiles()
public String[] getResults()
public void setupOptions(String[] args)
public static void main(String[] args)
|
GigaSpaces XAP 8.0 API | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |