3 package Devel::REPL::Plugin::B::Concise;
4 use Devel::REPL::Plugin;
8 B::Concise::compileOpts(qw(-nobanner));
10 use namespace::clean -except => [ 'meta' ];
12 with qw(Devel::REPL::Plugin::Turtles);
17 my $prefix = $self->default_command_prefix;
19 $self->add_turtles_matcher(qr/^
21 ( (?:\-\w+\s+)* ) # options for concise
26 sub expr_command_concise {
27 my ( $self, $eval, $opts, $code ) = @_;
31 my $sub = $self->compile($code, no_mangling => 1);
33 open my $fh, ">", \my $out;
36 B::Concise::compile((split /\s+/, $opts), $sub)->();
50 Devel::REPL::Plugin::B::Concise - B::Concise dumping of expression optrees
54 repl> #concise -exec -terse {
57 COP (0x138b1e0) nextstate
58 OP (0x13bd280) pushmark
59 SVOP (0x138c6a0) const PV (0xbbab50) "foo"
60 OP (0x13bbae0) pushmark
61 SVOP (0x13bcee0) gv GV (0xbbb250) *Devel::REPL::Plugin::B::Concise::foo
62 UNOP (0x13890a0) entersub [1]
63 LISTOP (0x13ba020) anonhash
64 UNOP (0x5983d0) leavesub [1]
68 This plugin provides a C<concise> command that uses L<B::Concise> to dump
69 optrees of expressions.
71 The code is not actually executed, which means that when used with
72 L<Deve::REPL::Plugin::OutputCache> there is .
74 The command takes the same options as L<B::Concise/compile>, e.g. C<-basic> or
75 C<-exec> to determine the dump order, C<-debug>, C<-concise> and C<-terse> to
76 determine the formatting, etc.
80 Yuval Kogman E<lt>nothingmuch@woobling.orgE<gt>