NAME

B::RecDeparse - Deparse recursively into subroutines.

VERSION

Version 0.10

SYNOPSIS

# Deparse recursively a Perl one-liner :
$ perl -MO=RecDeparse,deparse,@B__Deparse_opts,level,-1 -e '...'

# Or a complete Perl script :
$ perl -MO=RecDeparse,deparse,@B__Deparse_opts,level,-1 x.pl

# Or a single code reference :
use B::RecDeparse;

my $brd = B::RecDeparse->new(
 deparse => \@B__Deparse_opts,
 level   => $level,
);
my $code = $brd->coderef2text(sub { ... });

DESCRIPTION

This module extends B::Deparse by making it recursively replace subroutine calls encountered when deparsing.

Please refer to B::Deparse documentation for what to do and how to do it. Besides the constructor syntax, everything should work the same for the two modules.

METHODS

new

my $brd = B::RecDeparse->new(
 deparse => \@B__Deparse_opts,
 level   => $level,
);

The B::RecDeparse object constructor. You can specify the underlying B::Deparse constructor arguments by passing a string or an array reference as the value of the deparse key. The level option expects an integer that specifies how many levels of recursions are allowed : -1 means infinite while 0 means none and match B::Deparse behaviour.

The following functions and methods from B::Deparse are reimplemented by this module :

  • compile

  • init

  • deparse_sub

  • pp_entersub

  • pp_refgen

  • pp_srefgen

  • pp_gv

Otherwise, B::RecDeparse inherits all methods from B::Deparse.

EXPORT

An object-oriented module shouldn't export any function, and so does this one.

DEPENDENCIES

perl 5.8.1.

Carp (standard since perl 5), Config (since perl 5.00307) and B::Deparse (since perl 5.005).

AUTHOR

Vincent Pit, <perl at profvince.com>, http://www.profvince.com.

You can contact me by mail or on irc.perl.org (vincent).

BUGS

Please report any bugs or feature requests to bug-b-recdeparse at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=B-RecDeparse. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

SUPPORT

You can find documentation for this module with the perldoc command.

perldoc B::RecDeparse

Tests code coverage report is available at http://www.profvince.com/perl/cover/B-RecDeparse.

COPYRIGHT & LICENSE

Copyright 2008,2009,2010,2011,2013,2014,2015 Vincent Pit, all rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.