X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit%2FDevel-REPL.git;a=blobdiff_plain;f=lib%2FDevel%2FREPL%2FPlugin%2FDDS.pm;h=7940219bfb493b86fa77c5493834c79f1f07a58e;hp=6e01fe7145469f1289f3cad2ddaa14bbb950ea4b;hb=c45376f3de16a5a467a1a26e63a279f30eb8672d;hpb=e4761e81ea1521f1daf146e8e5ec066b40d35888 diff --git a/lib/Devel/REPL/Plugin/DDS.pm b/lib/Devel/REPL/Plugin/DDS.pm index 6e01fe7..7940219 100644 --- a/lib/Devel/REPL/Plugin/DDS.pm +++ b/lib/Devel/REPL/Plugin/DDS.pm @@ -1,35 +1,39 @@ +use strict; +use warnings; package Devel::REPL::Plugin::DDS; +# ABSTRACT: Format results with Data::Dump::Streamer + +our $VERSION = '1.003029'; use Devel::REPL::Plugin; use Data::Dump::Streamer (); +use namespace::autoclean; around 'format_result' => sub { - my $orig = shift; - my $self = shift; - my $to_dump = (@_ > 1) ? [@_] : $_[0]; - my $out; - if (ref $to_dump) { - if (overload::Method($to_dump, '""')) { - $out = "$to_dump"; - } else { - my $dds = Data::Dump::Streamer->new; - $dds->Freezer(sub { "$_[0]"; }); - $dds->Data($to_dump); - $out = $dds->Out; - } - } else { - $out = $to_dump; - } - $self->$orig($out); + my $orig = shift; + my $self = shift; + my @to_dump = @_; + my $out; + if (@to_dump > 1 || ref $to_dump[0]) { + if (@to_dump == 1 && overload::Method($to_dump[0], '""')) { + $out = "@to_dump"; + } else { + my $dds = Data::Dump::Streamer->new; + $dds->Freezer(sub { "$_[0]"; }); + $dds->Data(@to_dump); + $out = $dds->Out; + } + } else { + $out = $to_dump[0]; + } + $self->$orig($out); }; 1; __END__ -=head1 NAME - -Devel::REPL::Plugin::DDS - Format results with Data::Dump::Streamer +=pod =head1 SYNOPSIS @@ -50,4 +54,3 @@ Devel::REPL::Plugin::DDS - Format results with Data::Dump::Streamer $ =cut -