X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2Fvars.pm;h=0ace55169c42ba98c59e23215f466a8e5367a11a;hb=ad1ebafb1ecaed58230ed26d371e08c109ae3ac4;hp=ca2a08dcf6c9572fa1936cd26cfaf9a3bb79f39f;hpb=014aafb8a06f901623bd13c6c881fb238a5469d1;p=p5sagit%2Fp5-mst-13.2.git diff --git a/lib/vars.pm b/lib/vars.pm index ca2a08d..0ace551 100644 --- a/lib/vars.pm +++ b/lib/vars.pm @@ -9,6 +9,8 @@ require 5.002; # We'll let those bugs get found on the development track. require Carp if $] < 5.00450; +use warnings::register; + sub import { my $callpack = caller; my ($pack, @imports, $sym, $ch) = @_; @@ -22,9 +24,8 @@ sub import { } elsif ($sym =~ /^\w+[[{].*[]}]$/) { require Carp; Carp::croak("Can't declare individual elements of hash or array"); - } elsif ($^W and length($sym) == 1 and $sym !~ tr/a-zA-Z//) { - require Carp; - Carp::carp("No need to declare built-in vars"); + } elsif (warnings::enabled() and length($sym) == 1 and $sym !~ tr/a-zA-Z//) { + warnings::warn("No need to declare built-in vars"); } } *{"${callpack}::$sym"} = @@ -45,7 +46,7 @@ __END__ =head1 NAME -vars - Perl pragma to predeclare global variable names +vars - Perl pragma to predeclare global variable names (obsolete) =head1 SYNOPSIS @@ -53,6 +54,10 @@ vars - Perl pragma to predeclare global variable names =head1 DESCRIPTION +NOTE: The functionality provided by this pragma has been superseded +by C declarations, available in Perl v5.6.0 or later. See +L. + This will predeclare all the variables whose names are in the list, allowing you to use them under "use strict", and disabling any typo warnings.