NAME
trace - sufficiently advanced way to trace subroutine calls
SYNOPSIS
use trace along with ignore
, only
, or all
,
use trace;
use trace 'all'; # same as saying 'use trace;'
use trace 'none'; # filter the source but don't insert anything
use trace ignore => qw(man_behind_curtain skeletons_in_closet _private);
use trace only => qw(sex drugs rock_and_roll);
DESCRIPTION
trace is a source filter using Filter::Simple that prints the fully qualified subroutine name (package::subroutine) to standard error as the program runs.
This module is useful if...
You're a visual learner and want to "see" program execution
You're tracking an anomaly that leads you into unfamiliar code
You want to quickly see how a module _runs_
You've inherited code and need to grok it
You start a new job and want to get a fast track on how things work
EXAMPLES
#!/usr/bin/perl
use strict;
use warnings;
use trace;
use Example::Object;
init();
my $example = Example::Object->new();
my $name = $example->name();
my $result = $example->calc();
cleanup();
sub init {}
sub cleanup {}
# In a another file, say Example/Object.pm
package Example::Object;
use trace;
sub new { bless {}, shift }
sub name {}
sub calc {}
Produces the following output
# Hires seconds # package::sub
[1092265261.834574] main::init
[1092265261.836732] Example::Object::new
[1092265261.837563] Example::Object::name
[1092265261.838245] Example::Object::calc
[1092265261.839443] main::cleanup
BUGS
Please report any bugs or feature requests to bug-trace@rt.cpan.org
, or through the web interface at http://rt.cpan.org. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
MAD PROPS
This module was inspired by Damian Conway's Sufficently Advanced Technology presentation at YAPC::NA 2004. I had initially attempted to use Hook::LexWrap, but using Filter::Simple just seemed to be magical (and the first iteration was only 2 lines of code)
package trace;
use strict;
use warnings;
use Filter::Simple;
my $code = 'print STDERR (caller(0))[3] . "\n";';
FILTER { return unless $_; $_ =~ s/(sub.+?{)/$1 $code/sg; }
Also, I'd like to give a shout out goes to fellow SouthFlorida.pm homeboy and dark master of POE, Rocco Caputo, for pairing with me to work out the import logic. Rock on Rocco!
And my final props go out to the wild man Dennis Taylor, author of POE::Component::IRC, where I saw my first =head1 MAD PROPS
section. Maybe someday someone will see this MAD PROPS
section and it will inspire them to send MAD PROPS
back my way. A man has to have his dream... :D
AUTHOR
Copyright 2004 Jeff Bisbee <jbisbee@cpan.org>
http://search.cpan.org/~jbisbee/
LICENSE
Copyright 2004 Jeff, All Rights Reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.