Server IP : 103.119.228.120 / Your IP : 18.224.69.176 Web Server : Apache System : Linux v8.techscape8.com 3.10.0-1160.119.1.el7.tuxcare.els2.x86_64 #1 SMP Mon Jul 15 12:09:18 UTC 2024 x86_64 User : nobody ( 99) PHP Version : 5.6.40 Disable Function : shell_exec,symlink,system,exec,proc_get_status,proc_nice,proc_terminate,define_syslog_variables,syslog,openlog,closelog,escapeshellcmd,passthru,ocinum cols,ini_alter,leak,listen,chgrp,apache_note,apache_setenv,debugger_on,debugger_off,ftp_exec,dl,dll,myshellexec,proc_open,socket_bind,proc_close,escapeshellarg,parse_ini_filepopen,fpassthru,exec,passthru,escapeshellarg,escapeshellcmd,proc_close,proc_open,ini_alter,popen,show_source,proc_nice,proc_terminate,proc_get_status,proc_close,pfsockopen,leak,apache_child_terminate,posix_kill,posix_mkfifo,posix_setpgid,posix_setsid,posix_setuid,dl,symlink,shell_exec,system,dl,passthru,escapeshellarg,escapeshellcmd,myshellexec,c99_buff_prepare,c99_sess_put,fpassthru,getdisfunc,fx29exec,fx29exec2,is_windows,disp_freespace,fx29sh_getupdate,fx29_buff_prepare,fx29_sess_put,fx29shexit,fx29fsearch,fx29ftpbrutecheck,fx29sh_tools,fx29sh_about,milw0rm,imagez,sh_name,myshellexec,checkproxyhost,dosyayicek,c99_buff_prepare,c99_sess_put,c99getsource,c99sh_getupdate,c99fsearch,c99shexit,view_perms,posix_getpwuid,posix_getgrgid,posix_kill,parse_perms,parsesort,view_perms_color,set_encoder_input,ls_setcheckboxall,ls_reverse_all,rsg_read,rsg_glob,selfURL,dispsecinfo,unix2DosTime,addFile,system,get_users,view_size,DirFiles,DirFilesWide,DirPrintHTMLHeaders,GetFilesTotal,GetTitles,GetTimeTotal,GetMatchesCount,GetFileMatchesCount,GetResultFiles,fs_copy_dir,fs_copy_obj,fs_move_dir,fs_move_obj,fs_rmdir,SearchText,getmicrotime MySQL : ON | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /usr/share/perl5/vendor_perl/Log/Message/ |
Upload File : |
package Log::Message::Simple; use if $] > 5.017, 'deprecate'; use strict; use Log::Message private => 0;; BEGIN { use vars qw[$VERSION]; $VERSION = '0.10'; } =pod =head1 NAME Log::Message::Simple - Simplified interface to Log::Message =head1 SYNOPSIS use Log::Message::Simple qw[msg error debug carp croak cluck confess]; use Log::Message::Simple qw[:STD :CARP]; ### standard reporting functionality msg( "Connecting to database", $verbose ); error( "Database connection failed: $@", $verbose ); debug( "Connection arguments were: $args", $debug ); ### standard carp functionality carp( "Wrong arguments passed: @_" ); croak( "Fatal: wrong arguments passed: @_" ); cluck( "Wrong arguments passed -- including stacktrace: @_" ); confess("Fatal: wrong arguments passed -- including stacktrace: @_" ); ### retrieve individual message my @stack = Log::Message::Simple->stack; my @stack = Log::Message::Simple->flush; ### retrieve the entire stack in printable form my $msgs = Log::Message::Simple->stack_as_string; my $trace = Log::Message::Simple->stack_as_string(1); ### redirect output local $Log::Message::Simple::MSG_FH = \*STDERR; local $Log::Message::Simple::ERROR_FH = \*STDERR; local $Log::Message::Simple::DEBUG_FH = \*STDERR; ### force a stacktrace on error local $Log::Message::Simple::STACKTRACE_ON_ERROR = 1 =head1 DESCRIPTION This module provides standardized logging facilities using the C<Log::Message> module. =head1 FUNCTIONS =head2 msg("message string" [,VERBOSE]) Records a message on the stack, and prints it to C<STDOUT> (or actually C<$MSG_FH>, see the C<GLOBAL VARIABLES> section below), if the C<VERBOSE> option is true. The C<VERBOSE> option defaults to false. Exported by default, or using the C<:STD> tag. =head2 debug("message string" [,VERBOSE]) Records a debug message on the stack, and prints it to C<STDOUT> (or actually C<$DEBUG_FH>, see the C<GLOBAL VARIABLES> section below), if the C<VERBOSE> option is true. The C<VERBOSE> option defaults to false. Exported by default, or using the C<:STD> tag. =head2 error("error string" [,VERBOSE]) Records an error on the stack, and prints it to C<STDERR> (or actually C<$ERROR_FH>, see the C<GLOBAL VARIABLES> sections below), if the C<VERBOSE> option is true. The C<VERBOSE> options defaults to true. Exported by default, or using the C<:STD> tag. =cut { package Log::Message::Handlers; sub msg { my $self = shift; my $verbose = shift || 0; ### so you don't want us to print the msg? ### return if defined $verbose && $verbose == 0; my $old_fh = select $Log::Message::Simple::MSG_FH; print '['. $self->tag (). '] ' . $self->message . "\n"; select $old_fh; return; } sub debug { my $self = shift; my $verbose = shift || 0; ### so you don't want us to print the msg? ### return if defined $verbose && $verbose == 0; my $old_fh = select $Log::Message::Simple::DEBUG_FH; print '['. $self->tag (). '] ' . $self->message . "\n"; select $old_fh; return; } sub error { my $self = shift; my $verbose = shift; $verbose = 1 unless defined $verbose; # default to true ### so you don't want us to print the error? ### return if defined $verbose && $verbose == 0; my $old_fh = select $Log::Message::Simple::ERROR_FH; my $msg = '['. $self->tag . '] ' . $self->message; print $Log::Message::Simple::STACKTRACE_ON_ERROR ? Carp::shortmess($msg) : $msg . "\n"; select $old_fh; return; } } =head2 carp(); Provides functionality equal to C<Carp::carp()> while still logging to the stack. Exported by using the C<:CARP> tag. =head2 croak(); Provides functionality equal to C<Carp::croak()> while still logging to the stack. Exported by using the C<:CARP> tag. =head2 confess(); Provides functionality equal to C<Carp::confess()> while still logging to the stack. Exported by using the C<:CARP> tag. =head2 cluck(); Provides functionality equal to C<Carp::cluck()> while still logging to the stack. Exported by using the C<:CARP> tag. =head1 CLASS METHODS =head2 Log::Message::Simple->stack() Retrieves all the items on the stack. Since C<Log::Message::Simple> is implemented using C<Log::Message>, consult its manpage for the function C<retrieve> to see what is returned and how to use the items. =head2 Log::Message::Simple->stack_as_string([TRACE]) Returns the whole stack as a printable string. If the C<TRACE> option is true all items are returned with C<Carp::longmess> output, rather than just the message. C<TRACE> defaults to false. =head2 Log::Message::Simple->flush() Removes all the items from the stack and returns them. Since C<Log::Message::Simple> is implemented using C<Log::Message>, consult its manpage for the function C<retrieve> to see what is returned and how to use the items. =cut BEGIN { use Exporter; use Params::Check qw[ check ]; use vars qw[ @EXPORT @EXPORT_OK %EXPORT_TAGS @ISA ];; @ISA = 'Exporter'; @EXPORT = qw[error msg debug]; @EXPORT_OK = qw[carp cluck croak confess]; %EXPORT_TAGS = ( STD => \@EXPORT, CARP => \@EXPORT_OK, ALL => [ @EXPORT, @EXPORT_OK ], ); my $log = new Log::Message; for my $func ( @EXPORT, @EXPORT_OK ) { no strict 'refs'; ### up the carplevel for the carp emulation ### functions *$func = sub { local $Carp::CarpLevel += 2 if grep { $_ eq $func } @EXPORT_OK; my $msg = shift; $log->store( message => $msg, tag => uc $func, level => $func, extra => [@_] ); }; } sub flush { return reverse $log->flush; } sub stack { return $log->retrieve( chrono => 1 ); } sub stack_as_string { my $class = shift; my $trace = shift() ? 1 : 0; return join $/, map { '[' . $_->tag . '] [' . $_->when . '] ' . ($trace ? $_->message . ' ' . $_->longmess : $_->message); } __PACKAGE__->stack; } } =head1 GLOBAL VARIABLES =over 4 =item $ERROR_FH This is the filehandle all the messages sent to C<error()> are being printed. This defaults to C<*STDERR>. =item $MSG_FH This is the filehandle all the messages sent to C<msg()> are being printed. This default to C<*STDOUT>. =item $DEBUG_FH This is the filehandle all the messages sent to C<debug()> are being printed. This default to C<*STDOUT>. =item $STACKTRACE_ON_ERROR If this option is set to C<true>, every call to C<error()> will generate a stacktrace using C<Carp::shortmess()>. Defaults to C<false> =back =cut BEGIN { use vars qw[ $ERROR_FH $MSG_FH $DEBUG_FH $STACKTRACE_ON_ERROR ]; local $| = 1; $ERROR_FH = \*STDERR; $MSG_FH = \*STDOUT; $DEBUG_FH = \*STDOUT; $STACKTRACE_ON_ERROR = 0; } 1; # Local variables: # c-indentation-style: bsd # c-basic-offset: 4 # indent-tabs-mode: nil # End: # vim: expandtab shiftwidth=4: