X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=lib%2FCatalyst%2FLog.pm;h=e1953b23e84c1b1cdd7ab044556701cbf0ef3f55;hp=de7a447afc3a5ea8afca8f584fc40b4320638201;hb=4090e3bb3fea1a73ac369250e31584d61428b808;hpb=adee716c5ee8cda002acdaaa31764b72382101a3 diff --git a/lib/Catalyst/Log.pm b/lib/Catalyst/Log.pm index de7a447..e1953b2 100644 --- a/lib/Catalyst/Log.pm +++ b/lib/Catalyst/Log.pm @@ -1,18 +1,18 @@ package Catalyst::Log; -use strict; -use base 'Class::Accessor::Fast'; -use Data::Dumper; +use Moose; +use Data::Dump; our %LEVELS = (); -__PACKAGE__->mk_accessors('level'); -__PACKAGE__->mk_accessors('body'); -__PACKAGE__->mk_accessors('abort'); +has level => (is => 'rw'); +has _body => (is => 'rw'); +has abort => (is => 'rw'); { my @levels = qw[ debug info warn error fatal ]; + my $meta = __PACKAGE__->meta; for ( my $i = 0 ; $i < @levels ; $i++ ) { my $name = $levels[$i]; @@ -20,29 +20,28 @@ __PACKAGE__->mk_accessors('abort'); $LEVELS{$name} = $level; - no strict 'refs'; - - *{$name} = sub { + $meta->add_method($name, sub { my $self = shift; - if ( $self->{level} & $level ) { + if ( $self->level & $level ) { $self->_log( $name, @_ ); } - }; + }); - *{"is_$name"} = sub { + $meta->add_method("is_$name", sub { my $self = shift; - return $self->{level} & $level; - }; + return $self->level & $level; + });; } } -sub new { +around new => sub { + my $orig = shift; my $class = shift; - my $self = $class->SUPER::new; + my $self = $class->$orig; $self->levels( scalar(@_) ? @_ : keys %LEVELS ); return $self; -} +}; sub levels { my ( $self, @levels ) = @_; @@ -52,38 +51,46 @@ sub levels { sub enable { my ( $self, @levels ) = @_; - $self->{level} |= $_ for map { $LEVELS{$_} } @levels; + my $level = $self->level; + for(map { $LEVELS{$_} } @levels){ + $level |= $_; + } + $self->level($level); } sub disable { my ( $self, @levels ) = @_; - $self->{level} &= ~$_ for map { $LEVELS{$_} } @levels; + my $level = $self->level; + for(map { $LEVELS{$_} } @levels){ + $level &= ~$_; + } + $self->level($level); } sub _dump { my $self = shift; - local $Data::Dumper::Terse = 1; - $self->info( Dumper( @_ ) ); + $self->info( Data::Dump::dump(@_) ); } sub _log { my $self = shift; my $level = shift; - my $time = localtime(time); my $message = join( "\n", @_ ); - $self->{body} .= - sprintf( "[%s] [catalyst] [%s] %s\n", $time, $level, $message ); + $message .= "\n" unless $message =~ /\n$/; + my $body = $self->_body; + $body .= sprintf( "[%s] %s", $level, $message ); + $self->_body($body); } sub _flush { my $self = shift; - if ( $self->abort || !$self->body ) { + if ( $self->abort || !$self->_body ) { $self->abort(undef); } else { - $self->_send_to_log( $self->body ); + $self->_send_to_log( $self->_body ); } - $self->body(undef); + $self->_body(undef); } sub _send_to_log { @@ -91,6 +98,9 @@ sub _send_to_log { print STDERR @_; } +no Moose; +__PACKAGE__->meta->make_immutable(); + 1; __END__ @@ -124,6 +134,15 @@ e.g.: $c->log( MyLogger->new ); Your logging object is expected to provide the interface described here. +Good alternatives to consider are Log::Log4Perl and Log::Dispatch. + +If you want to be able to log arbitrary warnings, you can do something along +the lines of + + $SIG{__WARN__} = sub { MyApp->log->warn(@_); }; + +however this is (a) global, (b) hairy and (c) may have unexpected side effects. +Don't say we didn't warn you. =head1 LOG LEVELS @@ -162,6 +181,10 @@ arguments. $log = Catalyst::Log->new; $log = Catalyst::Log->new( 'warn', 'error' ); +=head2 level + +Contains a bitmask of the currently set log levels. + =head2 levels Set log levels @@ -210,6 +233,8 @@ This protected method is what actually sends the log information to STDERR. You may subclass this module and override this method to get finer control over the log output. +=head2 meta + =head1 SEE ALSO L. @@ -227,4 +252,6 @@ it under the same terms as Perl itself. =cut +__PACKAGE__->meta->make_immutable; + 1;