diff options
author | Gurusamy Sarathy <gsar@cpan.org> | 1999-06-27 13:49:31 +0000 |
---|---|---|
committer | Gurusamy Sarathy <gsar@cpan.org> | 1999-06-27 13:49:31 +0000 |
commit | 4f4e629e089f1120f8e94984281df06ac4f885c5 (patch) | |
tree | cc7f066c9893e0db84c4c487c16bb7dff5e029d6 /t | |
parent | d0334bed0b5f8315518daa5bbcd832e006b78148 (diff) | |
parent | d43ce814c3413c5d667db1dd8ade5d571ac81c1f (diff) | |
download | perl-4f4e629e089f1120f8e94984281df06ac4f885c5.tar.gz |
integrate cfgperl changes into mainline
p4raw-id: //depot/perl@3552
Diffstat (limited to 't')
-rwxr-xr-x | t/pragma/locale.t | 429 |
1 files changed, 280 insertions, 149 deletions
diff --git a/t/pragma/locale.t b/t/pragma/locale.t index b53a22809a..871c5d8d6b 100755 --- a/t/pragma/locale.t +++ b/t/pragma/locale.t @@ -14,6 +14,14 @@ use strict; my $debug = 1; +sub debug { + print @_ if $debug; +} + +sub debugf { + printf @_ if $debug; +} + my $have_setlocale = 0; eval { require POSIX; @@ -21,23 +29,15 @@ eval { $have_setlocale++; }; -use vars qw(&LC_ALL); - # Visual C's CRT goes silly on strings of the form "en_US.ISO8859-1" # and mingw32 uses said silly CRT $have_setlocale = 0 if $^O eq 'MSWin32' && $Config{cc} =~ /^(cl|gcc)/i; -# 103 (the last test) may fail but that is sort-of okay. -# (It indicates something broken in the environment, not Perl) - -print "1..", ($have_setlocale ? 103 : 98), "\n"; +print "1..", ($have_setlocale ? 115 : 98), "\n"; -use vars qw($a - $English $German $French $Spanish - @C @English @German @French @Spanish - $Locale @Locale %UPPER %lower %bothcase @Neoalpha); +use vars qw(&LC_ALL); -$a = 'abc %'; +my $a = 'abc %'; sub ok { my ($n, $result) = @_; @@ -229,40 +229,68 @@ exit unless $have_setlocale; # Find locales. +debug "# Scanning for locales...\n"; + +# Note that it's okay that some languages have their native names +# capitalized here even though that's not "right". They are lowercased +# anyway later during the scanning process (and besides, some clueless +# vendor might have them capitalized errorneously anyway). + my $locales = <<EOF; +Afrikaans:af:za:1 15 Arabic:ar:dz eg sa:6 arabic8 -Bulgarian:bg:bg:5 -Chinese:zh:cn tw:cn.EUC eucCN eucTW euc.CN euc.TW tw.EUC -Croation:hr:hr:2 +Brezhoneg Breton:br:fr:1 15 +Bulgarski Bulgarian:bg:bg:5 +Català Catalan:ca:es:1 15 +Chinese:zh:cn tw:cn.EUC eucCN eucTW euc.CN euc.TW GB2312 tw.EUC +Hrvatski Croatian:hr:hr:2 +Cymraeg Welsh:cy:cy:1 14 15 Czech:cs:cz:2 -Danish:dk:da:1 -Danish:dk:da:1 -Dutch:nl:nl:1 -English American British:en:au ca gb ie nz us uk:1 cp850 -Estonian:et:ee:1 -Finnish:fi:fi:1 -French:fr:be ca ch fr:1 -German:de:de at ch:1 -Greek:el:gr:7 g8 +Dansk Danish:dk:da:1 15 +Nederlands Dutch:nl:be nl:1 15 +English American British:en:au ca gb ie nz us uk:1 15 cp850 +Esperanto:eo:eo:3 +Eesti Estonian:et:ee:4 6 13 +Suomi Finnish:fi:fi:1 15 +Flamish::fl:1 15 +Français French:fr:be ca ch fr lu:1 15 +Deutsch German:de:at be ch de lu:1 15 +Euskaraz Basque:eu:es fr:1 15 +Gáidhlig Gaelic:gd:gb uk:1 14 15 +Galego Galician:gl:es:1 15 +Ellada Greek:el:gr:7 g8 +Føroyskt Faroese:fo:fo:1 15 +Frysk:fy:nl:1 15 +Greenlandic:kl:gl:4 6 Hebrew:iw:il:8 hebrew8 Hungarian:hu:hu:2 -Icelandic:is:is:1 -Italian:it:it:1 -Japanese:ja:jp:euc eucJP jp.EUC sjis +Íslensku Icelandic:is:is:1 15 +Indonesian:in:id:1 15 +Gaeilge Irish:ga:IE:1 14 15 +Italiano Italian:it:ch it:1 15 +Nihongo Japanese:ja:jp:euc eucJP jp.EUC sjis Korean:ko:kr: -Latin:la:va:1 -Latvian:lv:lv:1 -Lithuanian:lt:lt:1 -Polish:pl:pl:2 -Portuguese:po:po br:1 +Sámi Lappish:::4 6 13 +Latine Latin:la:va:1 15 +Latvian:lv:lv:4 6 13 +Lithuanian:lt:lt:4 6 13 +Macedonian:mk:mk:1 15 +Maltese:mt:mt:3 +Norsk Norwegian:no:no:1 15 +Occitan:oc:es:1 15 +Polski Polish:pl:pl:2 +Português Portuguese:po:po br:1 15 Rumanian:ro:ro:2 -Russian:ru:ru su:5 koi8 koi8r koi8u cp1251 +Russki Russian:ru:ru su ua:5 koi8 koi8r koi8u cp1251 +Serbski Serbian:sr:yu:5 Slovak:sk:sk:2 -Slovene:sl:si:2 -Spanish:es:ar bo cl co cr ec es gt mx ni pa pe py sv uy ve:1 -Swedish:sv:se:1 -Thai:th:th:tis620 +Slovene Slovenian:sl:si:2 +Espanõl Spanish:es:ar bo cl co cr do ec es gt hn mx ni pa pe py sv uy ve:1 15 +Sqhip Albanian:sq:sq:1 15 +Svenska Swedish:sv:fi se:1 15 +Thai:th:th:11 tis620 Turkish:tr:tr:9 turkish8 +Yiddish:::1 15 EOF my @Locale; @@ -302,8 +330,12 @@ trylocale("C"); trylocale("POSIX"); foreach (0..15) { trylocale("ISO8859-$_"); - trylocale("iso_8859_$_"); trylocale("iso8859$_"); + trylocale("iso8859-$_"); + trylocale("iso_8859_$_"); + trylocale("isolatin$_"); + trylocale("isolatin-$_"); + trylocale("iso_latin_$_"); } foreach my $locale (split(/\n/, $locales)) { @@ -337,19 +369,14 @@ foreach my $locale (split(/\n/, $locales)) { } } -@Locale = sort @Locale; +setlocale(LC_ALL, "C"); -sub debug { - print @_ if $debug; -} - -sub debugf { - printf @_ if $debug; -} +@Locale = sort @Locale; debug "# Locales = @Locale\n"; my %Problem; +my @Neoalpha; foreach $Locale (@Locale) { debug "# Locale = $Locale\n"; @@ -365,7 +392,9 @@ foreach $Locale (@Locale) { # Sieve the uppercase and the lowercase. - %UPPER = %lower = %bothcase = (); + my %UPPER = (); + my %lower = (); + my %BoThCaSe = (); for (@Alnum_) { if (/[^\d_]/) { # skip digits and the _ if (uc($_) eq $_) { @@ -377,19 +406,19 @@ foreach $Locale (@Locale) { } } foreach (keys %UPPER) { - $bothcase{$_}++ if exists $lower{$_}; + $BoThCaSe{$_}++ if exists $lower{$_}; } foreach (keys %lower) { - $bothcase{$_}++ if exists $UPPER{$_}; + $BoThCaSe{$_}++ if exists $UPPER{$_}; } - foreach (keys %bothcase) { + foreach (keys %BoThCaSe) { delete $UPPER{$_}; delete $lower{$_}; } debug "# UPPER = ", join(" ", sort keys %UPPER ), "\n"; debug "# lower = ", join(" ", sort keys %lower ), "\n"; - debug "# bothcase = ", join(" ", sort keys %bothcase), "\n"; + debug "# BoThCaSe = ", join(" ", sort keys %BoThCaSe), "\n"; # Find the alphabets that are not alphabets in the default locale. @@ -408,126 +437,223 @@ foreach $Locale (@Locale) { if (@Neoalpha == 0) { # If we have no Neoalphas the remaining tests are no-ops. - debug "# no Neoalpha, skipping tests 99..103 for locale '$Locale'\n"; - next; - } + debug "# no Neoalpha, skipping tests 99..102 for locale '$Locale'\n"; + } else { - # Test \w. + # Test \w. - debug "# testing 99 with locale '$Locale'\n"; - { - my $word = join('', @Neoalpha); + debug "# testing 99 with locale '$Locale'\n"; + { + my $word = join('', @Neoalpha); - $word =~ /^(\w+)$/; + $word =~ /^(\w+)$/; - if ($1 ne $word) { - $Problem{99}{$Locale} = 1; - debug "# failed 99 ($1 vs $word)\n"; + if ($1 ne $word) { + $Problem{99}{$Locale} = 1; + debug "# failed 99 ($1 vs $word)\n"; + } } - } - # Test #100 removed but to preserve historical test number - # consistency we do not renumber the remaining tests. + # Cross-check whole character set. - # Cross-check whole character set. - - debug "# testing 101 with locale '$Locale'\n"; - for (map { chr } 0..255) { - if ((/\w/ and /\W/) or (/\d/ and /\D/) or (/\s/ and /\S/)) { - $Problem{101}{$Locale} = 1; - debug "# failed 101\n"; - last; + debug "# testing 100 with locale '$Locale'\n"; + for (map { chr } 0..255) { + if ((/\w/ and /\W/) or (/\d/ and /\D/) or (/\s/ and /\S/)) { + $Problem{100}{$Locale} = 1; + debug "# failed 100 for chr(", ord(), ")\n"; + } } - } - # Test for read-only scalars' locale vs non-locale comparisons. + # Test for read-only scalars' locale vs non-locale comparisons. - debug "# testing 102 with locale '$Locale'\n"; - { - no locale; - $a = "qwerty"; + debug "# testing 101 with locale '$Locale'\n"; { - use locale; - if ($a cmp "qwerty") { - $Problem{102}{$Locale} = 1; - debug "# failed 102\n"; + no locale; + $a = "qwerty"; + { + use locale; + if ($a cmp "qwerty") { + $Problem{101}{$Locale} = 1; + debug "# failed 101\n"; + } } } - } - # This test must be the last one because its failure is not fatal. - # The @Alnum_ should be internally consistent. - # Thanks to Hallvard Furuseth <h.b.furuseth@usit.uio.no> - # for inventing a way to test for ordering consistency - # without requiring any particular order. - # <jhi@iki.fi> - - debug "# testing 103 with locale '$Locale'\n"; - { - my ($from, $to, $lesser, $greater, - @test, %test, $test, $yes, $no, $sign); - - for (0..9) { - # Select a slice. - $from = int(($_*@Alnum_)/10); - $to = $from + int(@Alnum_/10); - $to = $#Alnum_ if ($to > $#Alnum_); - $lesser = join('', @Alnum_[$from..$to]); - # Select a slice one character on. - $from++; $to++; - $to = $#Alnum_ if ($to > $#Alnum_); - $greater = join('', @Alnum_[$from..$to]); - ($yes, $no, $sign) = ($lesser lt $greater - ? (" ", "not ", 1) - : ("not ", " ", -1)); - # all these tests should FAIL (return 0). - # Exact lt or gt cannot be tested because - # in some locales, say, eacute and E may test equal. - @test = - ( - $no.' ($lesser le $greater)', # 1 - 'not ($lesser ne $greater)', # 2 - ' ($lesser eq $greater)', # 3 - $yes.' ($lesser ge $greater)', # 4 - $yes.' ($lesser ge $greater)', # 5 - $yes.' ($greater le $lesser )', # 7 - 'not ($greater ne $lesser )', # 8 - ' ($greater eq $lesser )', # 9 - $no.' ($greater ge $lesser )', # 10 - 'not (($lesser cmp $greater) == -$sign)' # 12 - ); - @test{@test} = 0 x @test; - $test = 0; - for my $ti (@test) { $test{$ti} = eval $ti ; $test ||= $test{$ti} } - if ($test) { - $Problem{103}{$Locale} = 1; - debug "# failed 103 at:\n"; - debug "# lesser = '$lesser'\n"; - debug "# greater = '$greater'\n"; - debug "# lesser cmp greater = ", $lesser cmp $greater, "\n"; - debug "# greater cmp lesser = ", $greater cmp $lesser, "\n"; - debug "# (greater) from = $from, to = $to\n"; + debug "# testing 102 with locale '$Locale'\n"; + { + my ($from, $to, $lesser, $greater, + @test, %test, $test, $yes, $no, $sign); + + for (0..9) { + # Select a slice. + $from = int(($_*@Alnum_)/10); + $to = $from + int(@Alnum_/10); + $to = $#Alnum_ if ($to > $#Alnum_); + $lesser = join('', @Alnum_[$from..$to]); + # Select a slice one character on. + $from++; $to++; + $to = $#Alnum_ if ($to > $#Alnum_); + $greater = join('', @Alnum_[$from..$to]); + ($yes, $no, $sign) = ($lesser lt $greater + ? (" ", "not ", 1) + : ("not ", " ", -1)); + # all these tests should FAIL (return 0). + # Exact lt or gt cannot be tested because + # in some locales, say, eacute and E may test equal. + @test = + ( + $no.' ($lesser le $greater)', # 1 + 'not ($lesser ne $greater)', # 2 + ' ($lesser eq $greater)', # 3 + $yes.' ($lesser ge $greater)', # 4 + $yes.' ($lesser ge $greater)', # 5 + $yes.' ($greater le $lesser )', # 7 + 'not ($greater ne $lesser )', # 8 + ' ($greater eq $lesser )', # 9 + $no.' ($greater ge $lesser )', # 10 + 'not (($lesser cmp $greater) == -$sign)' # 12 + ); + @test{@test} = 0 x @test; + $test = 0; for my $ti (@test) { - debugf("# %-40s %-4s", $ti, - $test{$ti} ? 'FAIL' : 'ok'); - if ($ti =~ /\(\.*(\$.+ +cmp +\$[^\)]+)\.*\)/) { - debugf("(%s == %4d)", $1, eval $1); - } - debug "\n#"; + $test{$ti} = eval $ti; + $test ||= $test{$ti} } + if ($test) { + $Problem{102}{$Locale} = 1; + debug "# failed 102 at:\n"; + debug "# lesser = '$lesser'\n"; + debug "# greater = '$greater'\n"; + debug "# lesser cmp greater = ", + $lesser cmp $greater, "\n"; + debug "# greater cmp lesser = ", + $greater cmp $lesser, "\n"; + debug "# (greater) from = $from, to = $to\n"; + for my $ti (@test) { + debugf("# %-40s %-4s", $ti, + $test{$ti} ? 'FAIL' : 'ok'); + if ($ti =~ /\(\.*(\$.+ +cmp +\$[^\)]+)\.*\)/) { + debugf("(%s == %4d)", $1, eval $1); + } + debug "\n#"; + } - last; + last; + } } } } -} -no locale; + use locale; + + my ($x, $y) = (1.23, 1.23); + + my $a = "$x"; + printf ''; # printf used to reset locale to "C" + my $b = "$y"; + + debug "# testing 103 with locale '$Locale'\n"; + unless ($a eq $b) { + $Problem{103}{$Locale} = 1; + debug "# failed 103\n"; + } + + my $c = "$x"; + my $z = sprintf ''; # sprintf used to reset locale to "C" + my $d = "$y"; + + debug "# 103..107: a = $a, b = $b, c = $c, d = $d, Locale = $Locale\n"; + + debug "# testing 104 with locale '$Locale'\n"; + unless ($c eq $d) { + $Problem{104}{$Locale} = 1; + debug "# failed 104\n"; + } + + my $w = 0; + local $SIG{__WARN__} = sub { $w++ }; + local $^W = 1; + + # the == (among other things) used to warn for locales + # that had something else than "." as the radix character + + debug "# testing 105 with locale '$Locale'\n"; + unless ($c == 1.23) { + $Problem{105}{$Locale} = 1; + debug "# failed 105\n"; + } + + debug "# testing 106 with locale '$Locale'\n"; + unless ($c == $x) { + $Problem{106}{$Locale} = 1; + debug "# failed 106\n"; + } + + debug "# testing 107 with locale '$Locale'\n"; + unless ($c == $d) { + $Problem{107}{$Locale} = 1; + debug "# failed 107\n"; + } + + { + no locale; + + my $e = "$x"; + + debug "# 108..110: e = $e, Locale = $Locale\n"; + + debug "# testing 108 with locale '$Locale'\n"; + unless ($e == 1.23) { + $Problem{108}{$Locale} = 1; + debug "# failed 108\n"; + } + + debug "# testing 109 with locale '$Locale'\n"; + unless ($e == $x) { + $Problem{109}{$Locale} = 1; + debug "# failed 109\n"; + } + + debug "# testing 110 with locale '$Locale'\n"; + unless ($e == $c) { + $Problem{110}{$Locale} = 1; + debug "# failed 110\n"; + } + } + + debug "# testing 111 with locale '$Locale'\n"; + unless ($w == 0) { + $Problem{110}{$Locale} = 1; + debug "# failed 111\n"; + } + + my $f = "1.23"; -foreach (99..103) { + debug "# 112..114: f = $f, locale = $Locale\n"; + + debug "# testing 112 with locale '$Locale'\n"; + unless ($f == 1.23) { + $Problem{112}{$Locale} = 1; + debug "# failed 112\n"; + } + + debug "# testing 113 with locale '$Locale'\n"; + unless ($f == $x) { + $Problem{113}{$Locale} = 1; + debug "# failed 113\n"; + } + + debug "# testing 114 with locale '$Locale'\n"; + unless ($f == $c) { + $Problem{114}{$Locale} = 1; + debug "# failed 114\n"; + } +} + +foreach (99..115) { if ($Problem{$_}) { - if ($_ == 103) { - print "# The failure of test 103 is not necessarily fatal.\n"; + if ($_ == 102) { + print "# The failure of test 102 is not necessarily fatal.\n"; print "# It usually indicates a problem in the enviroment,\n"; print "# not in Perl itself.\n"; } @@ -538,7 +664,7 @@ foreach (99..103) { my $didwarn = 0; -foreach (99..103) { +foreach (99..115) { if ($Problem{$_}) { my @f = sort keys %{ $Problem{$_} }; my $f = join(" ", @f); @@ -567,7 +693,7 @@ if ($didwarn) { foreach my $l (@Locale) { my $p = 0; - foreach my $t (99..103) { + foreach my $t (102..102) { $p++ if $Problem{$t}{$l}; } push @s, $l if $p == 0; @@ -582,4 +708,9 @@ if ($didwarn) { "# tested okay.\n#\n", } +{ + use locale; + +} + # eof |