| line | stmt | bran | cond | sub | pod | time | code | 
| 1 |  |  |  |  |  |  | # BEGIN BPS TAGGED BLOCK {{{ | 
| 2 |  |  |  |  |  |  | # COPYRIGHT: | 
| 3 |  |  |  |  |  |  | # | 
| 4 |  |  |  |  |  |  | # This software is Copyright (c) 2003-2008 Best Practical Solutions, LLC | 
| 5 |  |  |  |  |  |  | # | 
| 6 |  |  |  |  |  |  | # | 
| 7 |  |  |  |  |  |  | # (Except where explicitly superseded by other copyright notices) | 
| 8 |  |  |  |  |  |  | # | 
| 9 |  |  |  |  |  |  | # | 
| 10 |  |  |  |  |  |  | # LICENSE: | 
| 11 |  |  |  |  |  |  | # | 
| 12 |  |  |  |  |  |  | # | 
| 13 |  |  |  |  |  |  | # This program is free software; you can redistribute it and/or | 
| 14 |  |  |  |  |  |  | # modify it under the terms of either: | 
| 15 |  |  |  |  |  |  | # | 
| 16 |  |  |  |  |  |  | #   a) Version 2 of the GNU General Public License.  You should have | 
| 17 |  |  |  |  |  |  | #      received a copy of the GNU General Public License along with this | 
| 18 |  |  |  |  |  |  | #      program.  If not, write to the Free Software Foundation, Inc., 51 | 
| 19 |  |  |  |  |  |  | #      Franklin Street, Fifth Floor, Boston, MA 02110-1301 or visit | 
| 20 |  |  |  |  |  |  | #      their web page on the internet at | 
| 21 |  |  |  |  |  |  | #      http://www.gnu.org/copyleft/gpl.html. | 
| 22 |  |  |  |  |  |  | # | 
| 23 |  |  |  |  |  |  | #   b) Version 1 of Perl's "Artistic License".  You should have received | 
| 24 |  |  |  |  |  |  | #      a copy of the Artistic License with this package, in the file | 
| 25 |  |  |  |  |  |  | #      named "ARTISTIC".  The license is also available at | 
| 26 |  |  |  |  |  |  | #      http://opensource.org/licenses/artistic-license.php. | 
| 27 |  |  |  |  |  |  | # | 
| 28 |  |  |  |  |  |  | # This work is distributed in the hope that it will be useful, but | 
| 29 |  |  |  |  |  |  | # WITHOUT ANY WARRANTY; without even the implied warranty of | 
| 30 |  |  |  |  |  |  | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | 
| 31 |  |  |  |  |  |  | # General Public License for more details. | 
| 32 |  |  |  |  |  |  | # | 
| 33 |  |  |  |  |  |  | # CONTRIBUTION SUBMISSION POLICY: | 
| 34 |  |  |  |  |  |  | # | 
| 35 |  |  |  |  |  |  | # (The following paragraph is not intended to limit the rights granted | 
| 36 |  |  |  |  |  |  | # to you to modify and distribute this software under the terms of the | 
| 37 |  |  |  |  |  |  | # GNU General Public License and is only of importance to you if you | 
| 38 |  |  |  |  |  |  | # choose to contribute your changes and enhancements to the community | 
| 39 |  |  |  |  |  |  | # by submitting them to Best Practical Solutions, LLC.) | 
| 40 |  |  |  |  |  |  | # | 
| 41 |  |  |  |  |  |  | # By intentionally submitting any modifications, corrections or | 
| 42 |  |  |  |  |  |  | # derivatives to this work, or any other work intended for use with SVK, | 
| 43 |  |  |  |  |  |  | # to Best Practical Solutions, LLC, you confirm that you are the | 
| 44 |  |  |  |  |  |  | # copyright holder for those contributions and you grant Best Practical | 
| 45 |  |  |  |  |  |  | # Solutions, LLC a nonexclusive, worldwide, irrevocable, royalty-free, | 
| 46 |  |  |  |  |  |  | # perpetual, license to use, copy, create derivative works based on | 
| 47 |  |  |  |  |  |  | # those contributions, and sublicense and distribute those contributions | 
| 48 |  |  |  |  |  |  | # and any derivatives thereof. | 
| 49 |  |  |  |  |  |  | # | 
| 50 |  |  |  |  |  |  | # END BPS TAGGED BLOCK }}} | 
| 51 |  |  |  |  |  |  | package SVK::Logger; | 
| 52 | 188 |  |  | 188 |  | 2194 | use strict; | 
|  | 188 |  |  |  |  | 363 |  | 
|  | 188 |  |  |  |  | 8659 |  | 
| 53 | 188 |  |  | 188 |  | 1204 | use warnings; | 
|  | 188 |  |  |  |  | 383 |  | 
|  | 188 |  |  |  |  | 18376 |  | 
| 54 |  |  |  |  |  |  |  | 
| 55 | 188 |  |  | 188 |  | 1081 | use SVK::Version;  our $VERSION = $SVK::VERSION; | 
|  | 188 |  |  |  |  | 337 |  | 
|  | 188 |  |  |  |  | 89985 |  | 
| 56 |  |  |  |  |  |  |  | 
| 57 |  |  |  |  |  |  | if (eval { | 
| 58 |  |  |  |  |  |  | require Log::Log4perl; | 
| 59 |  |  |  |  |  |  | Log::Log4perl->import(':levels'); | 
| 60 |  |  |  |  |  |  | 1; | 
| 61 |  |  |  |  |  |  | } ) { | 
| 62 |  |  |  |  |  |  | my $level = lc($ENV{SVKLOGLEVEL} || "info"); | 
| 63 |  |  |  |  |  |  | $level = { map { $_ => uc $_ } qw( debug info warn error fatal ) } | 
| 64 |  |  |  |  |  |  | ->{ $level } || 'INFO'; | 
| 65 |  |  |  |  |  |  |  | 
| 66 |  |  |  |  |  |  | my $conf_file = $ENV{SVKLOGCONFFILE}; | 
| 67 |  |  |  |  |  |  | my $conf; | 
| 68 |  |  |  |  |  |  | if ( defined($conf_file) and -e $conf_file ) { | 
| 69 |  |  |  |  |  |  | my $fh; | 
| 70 |  |  |  |  |  |  | open $fh, $conf_file or die $!; | 
| 71 |  |  |  |  |  |  | local $/; | 
| 72 |  |  |  |  |  |  | $conf = <$fh>; | 
| 73 |  |  |  |  |  |  | close $fh; | 
| 74 |  |  |  |  |  |  | } | 
| 75 |  |  |  |  |  |  | #warn $conf unless $Log::Log4perl::Logger::INITIALIZED; | 
| 76 |  |  |  |  |  |  | $conf ||= qq{ | 
| 77 |  |  |  |  |  |  | log4perl.rootLogger=$level, Screen | 
| 78 |  |  |  |  |  |  | log4perl.appender.Screen = Log::Log4perl::Appender::Screen | 
| 79 |  |  |  |  |  |  | log4perl.appender.Screen.stderr = 0 | 
| 80 |  |  |  |  |  |  | log4perl.appender.Screen.layout = PatternLayout | 
| 81 |  |  |  |  |  |  | log4perl.appender.Screen.layout.ConversionPattern = %m%n | 
| 82 |  |  |  |  |  |  | }; | 
| 83 |  |  |  |  |  |  |  | 
| 84 |  |  |  |  |  |  | # ... passed as a reference to init() | 
| 85 |  |  |  |  |  |  | Log::Log4perl::init( \$conf ) unless Log::Log4perl->initialized; | 
| 86 |  |  |  |  |  |  | *get_logger = sub { Log::Log4perl->get_logger(@_) }; | 
| 87 |  |  |  |  |  |  | } | 
| 88 |  |  |  |  |  |  | else { | 
| 89 | 188 |  |  | 188 |  | 457 | *get_logger = sub { 'SVK::Logger::Compat' }; | 
| 90 |  |  |  |  |  |  | } | 
| 91 |  |  |  |  |  |  |  | 
| 92 |  |  |  |  |  |  | sub import { | 
| 93 | 188 |  |  | 188 |  | 440 | my $class = shift; | 
| 94 | 188 |  | 50 |  |  | 1610 | my $var = shift || 'logger'; | 
| 95 |  |  |  |  |  |  |  | 
| 96 |  |  |  |  |  |  | # it's ok if people add a sigil; we can get rid of that. | 
| 97 | 188 |  |  |  |  | 1246 | $var =~ s/^\$*//; | 
| 98 |  |  |  |  |  |  |  | 
| 99 |  |  |  |  |  |  | # Find out which package we'll export into. | 
| 100 | 188 |  |  |  |  | 720 | my $caller = caller() . ''; | 
| 101 |  |  |  |  |  |  |  | 
| 102 | 188 |  |  |  |  | 745 | (my $name = $caller) =~ s/::/./g; | 
| 103 | 188 |  |  |  |  | 865 | my $logger = get_logger(lc($name)); | 
| 104 |  |  |  |  |  |  | { | 
| 105 |  |  |  |  |  |  | # As long as we don't use a package variable, each module we export | 
| 106 |  |  |  |  |  |  | # into will get their own object. Also, this allows us to decide on | 
| 107 |  |  |  |  |  |  | # the exported variable name. Hope it isn't too bad form... | 
| 108 | 188 |  |  | 188 |  | 1398 | no strict 'refs'; | 
|  | 188 |  |  |  |  | 630 |  | 
|  | 188 |  |  |  |  | 117318 |  | 
|  | 188 |  |  |  |  | 685 |  | 
| 109 | 188 |  |  |  |  | 378 | *{ $caller . "::$var" } = \$logger; | 
|  | 188 |  |  |  |  | 31397 |  | 
| 110 |  |  |  |  |  |  | } | 
| 111 |  |  |  |  |  |  | } | 
| 112 |  |  |  |  |  |  |  | 
| 113 |  |  |  |  |  |  | package SVK::Logger::Compat; | 
| 114 |  |  |  |  |  |  | require Carp; | 
| 115 |  |  |  |  |  |  |  | 
| 116 |  |  |  |  |  |  | my $current_level; | 
| 117 |  |  |  |  |  |  | my $level; | 
| 118 |  |  |  |  |  |  |  | 
| 119 |  |  |  |  |  |  | BEGIN { | 
| 120 | 188 |  |  | 188 |  | 4149 | my $i; | 
| 121 | 188 |  |  |  |  | 499 | $level = { map { $_ => ++$i } reverse qw( debug info warn error fatal ) }; | 
|  | 940 |  |  |  |  | 3132 |  | 
| 122 | 188 |  | 33 |  |  | 3377 | $current_level = $level->{lc($ENV{SVKLOGLEVEL} || "info")} || $level->{info}; | 
| 123 |  |  |  |  |  |  |  | 
| 124 | 188 |  |  | 0 |  | 1078 | my $ignore  = sub { return }; | 
|  | 0 |  |  |  |  | 0 |  | 
| 125 |  |  |  |  |  |  | my $warn = sub { | 
| 126 | 0 |  |  | 0 |  | 0 | shift; | 
| 127 | 0 |  |  |  |  | 0 | my $s = join "", @_; | 
| 128 | 0 |  |  |  |  | 0 | chomp $s; | 
| 129 | 0 |  |  |  |  | 0 | print "$s\n"; | 
| 130 | 188 |  |  |  |  | 1108 | }; | 
| 131 | 188 |  |  | 0 |  | 879 | my $die     = sub { shift; die $_[0]."\n"; }; | 
|  | 0 |  |  |  |  | 0 |  | 
|  | 0 |  |  |  |  | 0 |  | 
| 132 | 188 |  |  | 0 |  | 711 | my $carp    = sub { shift; goto \&Carp::carp }; | 
|  | 0 |  |  |  |  | 0 |  | 
|  | 0 |  |  |  |  | 0 |  | 
| 133 | 188 |  |  | 0 |  | 1468 | my $confess = sub { shift; goto \&Carp::confess }; | 
|  | 0 |  |  |  |  | 0 |  | 
|  | 0 |  |  |  |  | 0 |  | 
| 134 | 188 |  |  | 0 |  | 875 | my $croak   = sub { shift; goto \&Carp::croak }; | 
|  | 0 |  |  |  |  | 0 |  | 
|  | 0 |  |  |  |  | 0 |  | 
| 135 |  |  |  |  |  |  |  | 
| 136 | 188 | 50 |  |  |  | 1259 | *debug      = $current_level >= $level->{debug} ? $warn : $ignore; | 
| 137 | 188 | 50 |  |  |  | 783 | *info       = $current_level >= $level->{info}  ? $warn : $ignore; | 
| 138 | 188 | 50 |  |  |  | 2084 | *warn       = $current_level >= $level->{warn}  ? $warn : $ignore; | 
| 139 | 188 | 50 |  |  |  | 833 | *error      = $current_level >= $level->{warn}  ? $warn : $ignore; | 
| 140 | 188 |  |  |  |  | 464 | *fatal      = $die; | 
| 141 | 188 |  |  |  |  | 375 | *logconfess = $confess; | 
| 142 | 188 |  |  |  |  | 418 | *logdie     = $die; | 
| 143 | 188 |  |  |  |  | 368 | *logcarp    = $carp; | 
| 144 | 188 |  |  |  |  | 20584 | *logcroak   = $croak; | 
| 145 |  |  |  |  |  |  |  | 
| 146 |  |  |  |  |  |  | } | 
| 147 |  |  |  |  |  |  |  | 
| 148 | 0 |  |  | 0 |  |  | sub is_debug { $current_level >= $level->{debug} } | 
| 149 |  |  |  |  |  |  |  | 
| 150 |  |  |  |  |  |  | 1; | 
| 151 |  |  |  |  |  |  |  | 
| 152 |  |  |  |  |  |  | __END__ |