NAME
App::PrereqGrapher - generate dependency graph using Perl::PrereqScanner
SYNOPSIS
use App::PrereqGrapher;
my %options = ( format => 'dot', output_file => 'prereqs.dot' );
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 takes two options:
- format
-
Select the output format, which must be one of the following:
- 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.
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.
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');
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 it's own file, then App::PrereqGrapher won't find it. For example Tie::StdHash is defined inside Tie::Hash, so you'll get the following error message:
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, and will warn if either of them isn't installed.
TODO
By default maybe we shouldn't warn if a module isn't found; could have a verbose option?
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.
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.
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 226:
Unknown directive: =head