X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2Fvars.pm;h=ca2a08dcf6c9572fa1936cd26cfaf9a3bb79f39f;hb=1ba752a043289c0682ba096aba08751ac71b298a;hp=5723ac6c2cbccee785a45109fdfbc0c508479e81;hpb=fb73857aa0bfa8ed43d4d2f972c564c70a57e0c4;p=p5sagit%2Fp5-mst-13.2.git diff --git a/lib/vars.pm b/lib/vars.pm index 5723ac6..ca2a08d 100644 --- a/lib/vars.pm +++ b/lib/vars.pm @@ -13,11 +13,20 @@ sub import { my $callpack = caller; my ($pack, @imports, $sym, $ch) = @_; foreach $sym (@imports) { - if ($sym =~ /::/) { - require Carp; - Carp::croak("Can't declare another package's variables"); - } ($ch, $sym) = unpack('a1a*', $sym); + if ($sym =~ tr/A-Za-z_0-9//c) { + # time for a more-detailed check-up + if ($sym =~ /::/) { + require Carp; + Carp::croak("Can't declare another package's variables"); + } 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"); + } + } *{"${callpack}::$sym"} = ( $ch eq "\$" ? \$ {"${callpack}::$sym"} : $ch eq "\@" ? \@ {"${callpack}::$sym"} @@ -26,7 +35,7 @@ sub import { : $ch eq "\&" ? \& {"${callpack}::$sym"} : do { require Carp; - Carp::croak("'$ch$sym' is not a valid variable name\n"); + Carp::croak("'$ch$sym' is not a valid variable name"); }); } }; @@ -61,6 +70,6 @@ outside of the package), it can act as an acceptable substitute by pre-declaring global symbols, ensuring their availability to the later-loaded routines. -See L. +See L. =cut