X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit%2FDevel-REPL.git;a=blobdiff_plain;f=lib%2FDevel%2FREPL%2FPlugin%2FColors.pm;h=66f7d6e5248b2d79055344229a5d782a76e59cc0;hp=898437db9a9f106c2c224e312882a05d2dc897a6;hb=796cd7ec80de14e45ca8221d545aceb7b9bc0b71;hpb=81d2f8e6b31c924b068e571a2b861f1ebaadf1af diff --git a/lib/Devel/REPL/Plugin/Colors.pm b/lib/Devel/REPL/Plugin/Colors.pm index 898437d..66f7d6e 100644 --- a/lib/Devel/REPL/Plugin/Colors.pm +++ b/lib/Devel/REPL/Plugin/Colors.pm @@ -1,8 +1,13 @@ +use strict; +use warnings; package Devel::REPL::Plugin::Colors; +# ABSTRACT: Add color to return values, warnings, and errors -use Moose::Role; +our $VERSION = '1.003027'; + +use Devel::REPL::Plugin; use Term::ANSIColor; -use namespace::clean -except => [ 'meta' ]; +use namespace::autoclean; has normal_color => ( is => 'rw', lazy => 1, @@ -14,7 +19,7 @@ has error_color => ( default => 'bold red', ); -around error_return => sub { +around format_error => sub { my $orig = shift; my $self = shift; return color($self->error_color) @@ -23,12 +28,15 @@ around error_return => sub { }; # we can't just munge @_ because that screws up DDS -around print => sub { +around format_result => sub { my $orig = shift; my $self = shift; - print {$self->out_fh} color($self->normal_color); - $orig->($self, @_); - print {$self->out_fh} color('reset'); + no warnings 'uninitialized'; + return join "", ( + color($self->normal_color), + $orig->($self, @_), + color('reset'), + ); }; # make arbitrary warns colored -- somewhat difficult because warn doesn't @@ -58,15 +66,10 @@ around execute => \&_wrap_warn; __END__ -=head1 NAME - -Devel::REPL::Plugin::Colors - add color to return values, warnings, and errors +=pod =head1 SYNOPSIS - #!/usr/bin/perl - - use lib './lib'; use Devel::REPL; my $repl = Devel::REPL->new;