NAME
App::PrereqGrapher - generate dependency graph using Perl::PrereqScanner
SYNOPSIS
use App::PrereqGrapher;
my %options = (
format => 'dot',
no_core => 0,
no_recurse_core => 1,
output_file => 'prereqs.dot'
verbose => 0,
);
my $grapher = App::PrereqGrapher->new( %options );
$grapher->generate_graph('Module::Path');
DESCRIPTION
App::PrereqGrapher builds a directed graph of the prereqs or dependencies for a file or module. It uses Perl::PrereqScanner to find the dependencies for the seed, and then repeatedly calls Perl::PrereqScanner on those dependencies, and so on, until all dependencies have been found.
It then saves the resulting graph to a file, using one of the five supported formats. The default format is 'dot', the format used by the GraphViz graph drawing toolkit.
If your code contains lines like:
require 5.006;
use 5.006;
Then you'll end up with a dependency labelled perl 5.006; this way you can see where you're dependent on modules which require different minimum versions of perl.
METHODS
new
The constructor understands the following options:
- format
-
Select the output format, which must be one of: dot, svg, vcg, gml, or html. See "OUTPUT FORMATS" for more about the supported output formats. If not specified, the default format is 'dot'.
- output_file
-
Specifies the name of the file to write the dependency graph into, including the extension. If not specified, the filename will be
dependencies
, with the extension set according to the format. - depth
-
Only generate the graph to the specified depth. If the complete dependency graph is very large, this option may help you get an overview.
- no_core
-
Don't include any modules which are core (included with perl) for the version of perl being used.
- no_recurse_core
-
When a core module is used, include it in the dependency graph, but don't show any of its dependencies.
- timeout
-
Specifies the timeout for Graph::Easy when its laying out the graph. This is mainly relevant for formats like SVG and HTML, where the graph layout is done in Perl. Defaults to 5 seconds.
- verbose
-
Display verbose logging as the grapher runs. Currently this will just tell you if a module was use'd or require'd, but couldn't be found locally.
generate_graph
Takes one or more seed items. Each item may be a module or the path to a perl file.
$grapher->generate_graph('Module::Path', 'Module::Version');
It will first try and interpret each item as a module, but if it can't find a module with the given name, it will try and interpret it as a file path. This means that if you have a file called strict
for example, then you won't be able to run:
$grapher->generate_graph('strict');
as it will be interpreted as the module of that name. Put an explicit path to stop this:
$grapher->generate_graph('./strict');
OUTPUT FORMATS
- dot
-
The format used by GraphViz and related tools.
- svg
-
Scalable Vector Graphics (SVG) a W3C standard. You have to install Graph::Easy::As_svg if you want to use this format.
- vcg
-
The VCG or GDL format.
- gml
-
Graph Markup Language, aka GraphML.
- html
-
Generate an HTML format with embedded CSS. I haven't been able to get this to work, but it's one of the formats supported by Graph::Easy.
KNOWN BUGS
Perl::PrereqScanner uses PPI to parse each item. PPI has a hard-coded limit for the size of file it's prepared to parse (currently just over 1M). This means that very large files will be ignored; for example Perl::Tidy cannot be graphed, and if you try and graph a file that use's Perl::Tidy, then it just won't appear in the graph.
If a class isn't defined in its own file, then App::PrereqGrapher won't find it; for example Tie::StdHash is defined inside Tie::Hash. By default these are silently ignored, but if you use the -verbose option you'll get the following warning:
can't find Tie::StdHash - keeping calm and carrying on.
Perl::PrereqScanner parses code and makes no attempt to determine whether any of it would actually run on your platform. For example, one module might decide at run-time whether to require
Foo::Bar or Foo::Baz, and might never use Foo::Baz on your OS. But Perl::PrereqScanner will see both of Foo::Bar and Foo::Baz as pre-reqs.
TODO
Have an option to control what depth we should recurse to? You might only be interested in the dependencies of your code, and their first level of dependencies.
Show some indication that we're running. It can take a long time to run if your ultimate dependency graph is very large.
SEE ALSO
The distribution for this module contains a command-line script, prereq-grapher. It has its own documentation.
This module uses Perl::PrereqScanner to parse the source code, and Graph::Easy to generate and save the dependency graph.
http://neilb.org/reviews/dependencies.html: a review of CPAN modules that can be used to get dependency information.
REPOSITORY
https://github.com/neilbowers/App-PrereqGrapher
AUTHOR
Neil Bowers <neilb@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2012 by Neil Bowers <neilb@cpan.org>.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.