NAME
Tangerine - Examine perl files and report dependency metadata
SYNOPSIS
use Tangerine;
use version 0.77;
my $scanner = Tangerine->new(file => $file, mode => 'all');
$scanner->run;
print "$file contains the following modules: ".
join q/, /, sort keys %{$scanner->package}."\n";
print "$file requires Exporter, at runtime, on the following lines: ".
join q/, /, sort map $_->line, @{$scanner->runtime->{Exporter}}."\n";
my $v = 0;
for (@{$scanner->compile->{'Test::More'}}) {
$v = $_->version if $_->version && qv($v) < qv($_->version)
}
print "The minimum version of Test::More required by $file is $v.\n";
DESCRIPTION
Tangerine examines perl files and reports dependency metadata -- provided modules, and both compile-time and run-time dependencies, along with line numbers, versions and possibly other related information.
Currently, PPI is used for the initial parsing and statement extraction.
CONSTRUCTOR
new
-
Creates the Tangerine object. Takes the following two named arguments:
'file', the file to examine 'mode', determines what to look for; may be one of 'all', 'package', 'compile', or 'runtime'.
Both arguments are optional, however, 'file' needs to be set before running the scanner, e.g.
my $scanner = Tangerine->new; $scanner->file($file); $scanner->run;
METHODS
run
-
Runs the analysis.
package
-
Returns a hash reference. Keys are the modules provided, values references to lists of Tangerine::Occurence objects.
compile
-
Returns a hash reference. Keys are the modules required at compile-time, values references to lists of Tangerine::Occurence objects.
runtime
-
Returns a hash reference. Keys are the modules required at run-time, values references to lists of Tangerine::Occurence objects.
provides
requires
uses
-
Deprecated. These are provided for backwards compatibility only.
SEE ALSO
AUTHOR
Petr Šabata <contyk@redhat.com>
COPYRIGHT AND LICENSE
Copyright (c) 2014-2015 Petr Šabata
See LICENSE for licensing details.