diff options
author | Rafael Garcia-Suarez <rgarciasuarez@gmail.com> | 2006-06-20 22:01:16 +0000 |
---|---|---|
committer | Rafael Garcia-Suarez <rgarciasuarez@gmail.com> | 2006-06-20 22:01:16 +0000 |
commit | 8edeb3adf78562499e1eeea00d9ecf5f58e8de2d (patch) | |
tree | 747dbcc89e36f9bdca8fd1a386b56e323f916cff /ext/Sys/Syslog | |
parent | 9badc3612459020624c762b543ab7dd82718f170 (diff) | |
download | perl-8edeb3adf78562499e1eeea00d9ecf5f58e8de2d.tar.gz |
Upgrade to Sys::Syslog 0.16
p4raw-id: //depot/perl@28410
Diffstat (limited to 'ext/Sys/Syslog')
-rw-r--r-- | ext/Sys/Syslog/Changes | 23 | ||||
-rw-r--r-- | ext/Sys/Syslog/Syslog.pm | 28 | ||||
-rwxr-xr-x | ext/Sys/Syslog/t/syslog.t | 1 |
3 files changed, 33 insertions, 19 deletions
diff --git a/ext/Sys/Syslog/Changes b/ext/Sys/Syslog/Changes index ce33e1901d..abc07dfb63 100644 --- a/ext/Sys/Syslog/Changes +++ b/ext/Sys/Syslog/Changes @@ -1,7 +1,18 @@ Revision history for Sys-Syslog +0.16 -- 2006.06.20 -- Sebastien Aperghis-Tramoni (SAPER) + [BUGFIX] Perl-RT#20557: Save errno before trying to connect. + [FEATURE] Perl-RT#35406: Applied the patch proposed by Keisuke Hirata + for a more lax handling of "stream" or "unix" path. + [FEATURE] Now try the "native" mechanism first. + [TESTS] Silence warnings generated by t/syslog.t in Perl 5.8.8 and + later. + [DOC] Added documentation about the "native" mechanism. + [DOC] Now indicates whether tickets are from CPAN or Perl RT. + + 0.15 -- 2006.06.10 -- Sebastien Aperghis-Tramoni (SAPER) - [FEATURE] RT#17316: Added a "nofatal" option to openlog(). + [FEATURE] CPAN-RT#17316: Added a "nofatal" option to openlog(). [FEATURE] Sys::Syslog warnings can now be controled by the warnings category of the same name. [FEATURE] Added support for using the native C syslog(3) functions. @@ -10,13 +21,13 @@ Revision history for Sys-Syslog parentheses. 0.14 -- 2006.05.25 -- Sebastien Aperghis-Tramoni (SAPER) - [BUGFIX] RT#19259, RT#17518: Now allowing all levels and facilities. + [BUGFIX] CPAN-RT#19259, #17518: Now allowing all levels and facilities. [CODE] Removed useless "&". [CODE] Improved readability by adding empty lines and reworking the code here and there. [CODE] Added new macros from Mac OS X. [TESTS] Added more tests in order to increase coverage. - [DOC] RT#19085: Corrected errors in the documentation for setlogmask(). + [DOC] CPAN-RT#19085: Corrected errors in the documentation for setlogmask(). [DOC] Added several links to online manual pages, RFCs and articles. [DOC] Corrected minor things in Changes. @@ -29,9 +40,9 @@ Revision history for Sys-Syslog use INADDR_LOOPBACK. [CODE] Merged blead@26772: $host needs to stay in case the user sets it. [CODE] Merged blead@26773: check that $syslog_path is a socket. - [TESTS] RT#16980 (Alan Burlison): Sys::Syslog blows up rather + [TESTS] CPAN-RT#16980 (Alan Burlison): Sys::Syslog blows up rather spectacularly on Solaris. Corrected by previous patches. - [TESTS] RT#16974: Failed test in t/podspell. This test is now skipped. + [TESTS] CPAN-RT#16974: Failed test in t/podspell. This test is now skipped. 0.12 -- 2006.01.07 -- Sebastien Aperghis-Tramoni (SAPER) [DOC] Added a link to an article about Sys::Syslog. @@ -48,7 +59,7 @@ Revision history for Sys-Syslog [FEATURE] Support for three Exporter tags. [FEATURE] XSLoader is now optional. [CODE] No longer "use"s Sys::Hostname as it was "require"d where needed. - [CODE] RT#16604: Use local timestamp. + [CODE] CPAN-RT#16604: Use local timestamp. [DIST] Merged blead@26343: Fix realclean target. [DOC] Improved documentation. [TESTS] Added more tests to t/syslog.t in order to increase code coverage. diff --git a/ext/Sys/Syslog/Syslog.pm b/ext/Sys/Syslog/Syslog.pm index fe75005b5d..a5bad2e4cb 100644 --- a/ext/Sys/Syslog/Syslog.pm +++ b/ext/Sys/Syslog/Syslog.pm @@ -8,7 +8,7 @@ require 5.006; require Exporter; { no strict 'vars'; - $VERSION = '0.15'; + $VERSION = '0.16'; @ISA = qw(Exporter); %EXPORT_TAGS = ( @@ -73,7 +73,7 @@ my %options = ( # it would be nice to try stream/unix first, since that will be # most efficient. However streams are dodgy - see _syslog_send_stream -my @connectMethods = ( 'tcp', 'udp', 'unix', 'stream', 'console' ); +my @connectMethods = qw(native tcp udp unix stream console); if ($^O =~ /^(freebsd|linux)$/) { @connectMethods = grep { $_ ne 'udp' } @connectMethods; } @@ -156,8 +156,8 @@ sub setlogsock { } } elsif (lc $setsock eq 'unix') { - if (length _PATH_LOG() && !defined $syslog_path) { - $syslog_path = _PATH_LOG(); + if (length _PATH_LOG() || (defined $syslog_path && -w $syslog_path)) { + $syslog_path = _PATH_LOG() unless defined $syslog_path; @connectMethods = ( 'unix' ); } else { warnings::warnif 'unix passed to setlogsock, but path not available'; @@ -203,18 +203,19 @@ sub syslog { my (@words, $num, $numpri, $numfac, $sum); my $failed = undef; my $fail_time = undef; + my $error = $!; my $facility = $facility; # may need to change temporarily. croak "syslog: expecting argument \$priority" unless defined $priority; croak "syslog: expecting argument \$format" unless defined $mask; - @words = split(/\W+/, $priority, 2);# Allow "level" or "level|facility". + @words = split(/\W+/, $priority, 2); # Allow "level" or "level|facility". undef $numpri; undef $numfac; foreach (@words) { - $num = xlate($_); # Translate word to number. + $num = xlate($_); # Translate word to number. if ($num < 0) { croak "syslog: invalid level/facility: $_" } @@ -240,11 +241,10 @@ sub syslog { connect_log() unless $connected; if ($mask =~ /%m/) { - my $err = $!; # escape percent signs if sprintf will be called - $err =~ s/%/%%/g if @_; + $error =~ s/%/%%/g if @_; # replace %m with $err, if preceded by an even number of percent signs - $mask =~ s/(?<!%)((?:%%)*)%m/$1$err/g; + $mask =~ s/(?<!%)((?:%%)*)%m/$1$error/g; } $mask .= "\n" unless $mask =~ /\n$/; @@ -503,7 +503,7 @@ sub connect_stream { my ($errs) = @_; # might want syslog_path to be variable based on syslog.h (if only # it were in there!) - $syslog_path = '/dev/conslog'; + $syslog_path = '/dev/conslog' unless defined $syslog_path; if (!-w $syslog_path) { push @$errs, "stream $syslog_path is not writable"; return 0; @@ -518,7 +518,7 @@ sub connect_stream { sub connect_unix { my ($errs) = @_; - if (length _PATH_LOG()) { + if (not defined $syslog_path and length _PATH_LOG()) { $syslog_path = _PATH_LOG(); } else { push @$errs, "_PATH_LOG not available in syslog.h"; @@ -619,7 +619,7 @@ Sys::Syslog - Perl interface to the UNIX syslog(3) calls =head1 VERSION -Version 0.15 +Version 0.16 =head1 SYNOPSIS @@ -810,9 +810,11 @@ C<undef> on failure. A value of C<"unix"> will connect to the UNIX domain socket (in some systems a character special device) returned by the C<_PATH_LOG> macro (if your system defines it), or F</dev/log> or F</dev/conslog>, -whatever is writable. A value of 'stream' will connect to the stream +whatever is writable. A value of C<"stream"> will connect to the stream indicated by the pathname provided as the optional second parameter. (For example Solaris and IRIX require C<"stream"> instead of C<"unix">.) +A value of C<"native"> will use the native C functions from your C<syslog(3)> +library. A value of C<"inet"> will connect to an INET socket (either C<tcp> or C<udp>, tried in that order) returned by C<getservbyname()>. C<"tcp"> and C<"udp"> can also be given as values. The value C<"console"> will send messages diff --git a/ext/Sys/Syslog/t/syslog.t b/ext/Sys/Syslog/t/syslog.t index 030a0ebc66..76353e9bdc 100755 --- a/ext/Sys/Syslog/t/syslog.t +++ b/ext/Sys/Syslog/t/syslog.t @@ -14,6 +14,7 @@ use Test::More; # we enable all Perl warnings, but we don't "use warnings 'all'" because # we want to disable the warnings generated by Sys::Syslog +no warnings; use warnings qw(closure deprecated exiting glob io misc numeric once overflow pack portable recursion redefine regexp severe signal substr syntax taint uninitialized unpack untie utf8 void); |