Sepia::Xref - Generates cross reference database for use by Perl programs.
use Sepia::Xref qw(rebuild defs callers); rebuild; for (defs 'foo') { printf "%s:%d: sub %s\::foo() defined\n", @{$_}[0..2]; } for (callers 'foo') { printf "%s:%d: sub foo() called by %s\::%s().\n", @{$_}[0..3]; }
Sepia::Xref is intended as a programmatic interface to the information supplied by B::Xref. It is intended to be a component for interactive Perl development, with other packages providing a friendly interface to the raw information it extracts. B::Xref could be seen as an example of this sort of user-level tool, if it weren't for the fact that this module was created later, and stole most of its code.
Sepia::Xref
B::Xref
%call
A map of subs to call locations and callers
%callby
A map of subs to subs called.
%var_use
A map of global/package variables to uses.
%var_def
A map of global/package variables to definitions (usually empty, since it only picks up local (...) declarations.
guess_module_file($pack, $ofile)
XXX: it turns out that rooting around trying to figure out the file ourselves is more reliable than what we grab from the op. Are we doing this wrong?
rebuild()
Rebuild the Xref database.
forget($func [, $mod])
Forget that $func was defined.
$func
redefined($func [, $pack])
Recompute xref info for $func, or $pack::$func if $pack given.
$pack::$func
$pack
callers($func)
List callers of $func.
callees($func)
List callees of $func.
var_defs($var)
Find locations where $var is defined.
$var
var_uses($var)
Find locations where $var is used.
var_assigns($var)
Find locations where $var is assigned to.
file_modules($file)
List the modules defined in file $file.
$file
var_apropos($expr)
Find variables matching $expr.
$expr
Nothing by default, but all sub and variable described above can be imported. Sepia::Xref also defines the tags :most for the above-listed functions, and :all for those and the variables as well.
:most
:all
Both should be done more cleanly and effectively. This is a hack because I don't quite understand what perl saves. We should be able to do as well as its warning messages.
Some "internal" packages are deliberately not cross-referenced, either because they are hairy and cause us problems, or because they are so commonly included as to be uninteresting. The current list includes all pragmatic modules, plus: B, O, AutoLoader, DynaLoader, XSLoader, Config, DB, VMS, FileHandle, Exporter, Carp, PerlIO::Layer.
Ideally, clicking the function names in tree view would take you to that function. This doesn't work. Also, more keys (like "q" to quit) should be implemented.
B::Xref, of which Sepia::Xref is a bastard child.
B::Xref by Malcolm Beattie, m(angl|odifi)ed by Sean O'Rourke (seano@cpan.org).
2 POD Errors
The following errors were encountered while parsing the POD:
You forgot a '=back' before '=head2'
'=item' outside of any '=over'
To install Sepia, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Sepia
CPAN shell
perl -MCPAN -e shell install Sepia
For more information on module installation, please visit the detailed CPAN module installation guide.