diff options
author | Jarkko Hietaniemi <jhi@iki.fi> | 2002-05-18 04:14:25 +0000 |
---|---|---|
committer | Jarkko Hietaniemi <jhi@iki.fi> | 2002-05-18 04:14:25 +0000 |
commit | 08cd7fd68a37c0884dd1698ef154f2d6583874ef (patch) | |
tree | 3d15f2b0d778ae668985c6a4b0217327228900b3 | |
parent | 3ca7705ebd432c2fb3599731fec8760f14fddd0f (diff) | |
download | perl-08cd7fd68a37c0884dd1698ef154f2d6583874ef.tar.gz |
Make use vars grok UTF-8.
p4raw-id: //depot/perl@16670
-rw-r--r-- | lib/vars.pm | 54 | ||||
-rw-r--r-- | t/run/fresh_perl.t | 10 |
2 files changed, 36 insertions, 28 deletions
diff --git a/lib/vars.pm b/lib/vars.pm index 020568e9e0..a57f4796b8 100644 --- a/lib/vars.pm +++ b/lib/vars.pm @@ -12,36 +12,34 @@ sub import { my ($pack, @imports) = @_; my ($sym, $ch); foreach (@imports) { - # TODO: UTF-8 names: (the unpack is quite wrong, - # /^(.)(.*)/ would probably be better.) While you - # are at it, until declaring empty package is made - # to work the * is too lenient. - ($ch, $sym) = unpack('a1a*', $_); - if ($sym =~ tr/A-Za-z_0-9//c) { - # time for a more-detailed check-up - if ($sym =~ /^\w+[[{].*[]}]$/) { - require Carp; - Carp::croak("Can't declare individual elements of hash or array"); - } elsif (warnings::enabled() and length($sym) == 1 and $sym !~ tr/a-zA-Z//) { - warnings::warn("No need to declare built-in vars"); - } elsif (($^H &= strict::bits('vars'))) { - # TODO: UTF-8 names: be careful to load the UTF-8 - # machinery only if the symbol requires it. - require Carp; - Carp::croak("'$_' is not a valid variable name under strict vars"); + if (($ch, $sym) = /^([\$\@\%\*\&])(.+)/) { + if ($sym =~ /\W/) { + # time for a more-detailed check-up + if ($sym =~ /^\w+[[{].*[]}]$/) { + require Carp; + Carp::croak("Can't declare individual elements of hash or array"); + } elsif (warnings::enabled() and length($sym) == 1 and $sym !~ tr/a-zA-Z//) { + warnings::warn("No need to declare built-in vars"); + } elsif (($^H &= strict::bits('vars'))) { + require Carp; + Carp::croak("'$_' is not a valid variable name under strict vars"); + } } + $sym = "${callpack}::$sym" unless $sym =~ /::/; + *$sym = + ( $ch eq "\$" ? \$$sym + : $ch eq "\@" ? \@$sym + : $ch eq "\%" ? \%$sym + : $ch eq "\*" ? \*$sym + : $ch eq "\&" ? \&$sym + : do { + require Carp; + Carp::croak("'$_' is not a valid variable name"); + }); + } else { + require Carp; + Carp::croak("'$_' is not a valid variable name"); } - $sym = "${callpack}::$sym" unless $sym =~ /::/; - *$sym = - ( $ch eq "\$" ? \$$sym - : $ch eq "\@" ? \@$sym - : $ch eq "\%" ? \%$sym - : $ch eq "\*" ? \*$sym - : $ch eq "\&" ? \&$sym - : do { - require Carp; - Carp::croak("'$_' is not a valid variable name"); - }); } }; diff --git a/t/run/fresh_perl.t b/t/run/fresh_perl.t index 1f8c5ce860..3c0a9259ad 100644 --- a/t/run/fresh_perl.t +++ b/t/run/fresh_perl.t @@ -821,3 +821,13 @@ $人++; # a child is born print $人, "\n"; EXPECT 3 +######## example from Camel 5, ch. 15, pp.406 (with use vars) +# SKIP: ord "A" == 193 # EBCDIC +use strict; +use utf8; +use vars qw($人); +$人 = 2; # 0xe4 0xba 0xba: U+4eba, "human" in CJK ideograph +$人++; # a child is born +print $人, "\n"; +EXPECT +3 |