Acme-Echo
view release on metacpan or search on metacpan
lib/Acme/Echo.pm view on Meta::CPAN
package Acme::Echo;
use warnings;
use strict;
our $VERSION = '0.02';
use Filter::Simple;
use PPI;
our %modes;
our $line_fmt = "%s\n";
our $src_fmt = "==>\n%s\n<==\n";
our $fh = *STDOUT;
sub import {
my $pkg = shift;
while ( $_ = shift @_ ){
if( /^before|after|lines$/ ){
$modes{ lc $_ } = undef;
}elsif( $_ eq 'line_fmt' ){
$line_fmt = shift;
}elsif( $_ eq 'src_fmt' ){
$src_fmt = shift;
}elsif( $_ eq 'fh' ){
$fh = shift;
}else{
die "bad parameter '$_' to Acme::Echo";
}
}
}
FILTER {
my $src = $_;
my $print = 'print $Acme::Echo::fh';
$_ = exists $modes{lines}
?
do {
my $s = "";
my $d = PPI::Document->new(\$src);
foreach my $node ( @{ $d->find('PPI::Statement') } ){
next unless $node->parent == $d;
if( $node->class eq 'PPI::Statement::Compound' ){
$s .= "$print q{COMPOUND STATEMENTS NOT SUPPORTED IN lines MODE\n};\n" . $node->content;
}elsif( $node->class eq 'PPI::Statement::Sub' ){
$s .= "$print q{SUB STATEMENTS NOT SUPPORTED IN lines MODE\n};\n" . $node->content;
}else{
$s .= sprintf "$print q{$line_fmt}; %s\n", $node->content, $node->content;
}
}
$s;
}
: $src ;
my $block = sprintf "\n;$print q{$src_fmt};\n", $src;
$_ = $block . $_ if exists $modes{before};
$_ = $_ . $block if exists $modes{after};
};
1;
__END__
=pod
=head1 NAME
Acme::Echo - Display perl statements before, after, and/or during execution
=head1 VERSION
Version 0.02
=head1 SYNOPSIS
use Acme::Echo qw/lines/;
print "hello world\n";
print "blah\n";
no Acme::Echo;
print "foo\n";
my $srclog;
BEGIN{ open $srclog, '>', "srclog.txt" or die; }
use Acme::Echo 'after', src_fmt=>"This code was just executed==>\n%s\n<==\n", fh=>$srclog;
...
=head1 IMPORT PARAMETERS
One or more of before/after/lines may be specified. At least one shoud be specified (pointless otherwise). The others are optional.
=over 2
=item before
Print out the entire code source before execution.
=item after
Print out the entire code source after execution.
=item lines
Print out each line of source right before its execution (note Limitations below).
=item line_fmt
( run in 1.055 second using v1.01-cache-2.11-cpan-2398b32b56e )