1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
#!/usr/bin/perl -w
use strict;
use diagnostics;
$| = 1; # autoflush
use vars qw(@ARGV $ARGV);
use Jcode;
my ($NTESTS, @TESTS) ;
sub profile {
no strict 'vars';
my $profile = shift;
print $profile if $ARGV[0];
$profile =~ m/(not ok|ok) (\d+)$/o;
$profile = "$1 $2\n";
$NTESTS = $2;
push @TESTS, $profile;
}
my $n = 0;
my $file;
my $hiragana; $file = "t/hiragana.euc"; open F, $file or die "$file:$!";
read F, $hiragana, -s $file;
profile(sprintf("prep: hiragana ok %d\n", ++$n));
my $katakana; $file = "t/zenkaku.euc"; open F, $file or die "$file:$!";
read F, $katakana, -s $file;
profile(sprintf("prep: katakana ok %d\n", ++$n));
#print jcode($katakana)->tr('A-Za-z-','a-zA-Z-');
#__END__
my %code2str =
(
'A-Za-z-' => $katakana,
'a-zA-Z-' => $hiragana,
);
# by Value
for my $icode (keys %code2str){
for my $ocode (keys %code2str){
my $ok;
my $str = $code2str{$icode};
my $out = jcode(\$str)->tr($icode, $ocode)->euc;
if ($out eq $code2str{$ocode}){
$ok = "ok";
}else{
$ok = "not ok";
print $out;
}
profile(sprintf("H2Z: %s -> %s %s %d\n",
$icode, $ocode, $ok, ++$n ));
}
}
print 1, "..", $NTESTS, "\n";
for my $TEST (@TESTS){
print $TEST;
}
|