X-Git-Url: http://lab.mitty.jp/git/?a=blobdiff_plain;f=misc%2Ffindcombinable.pl;h=8d515d962ac490e3630572d2539e5d51660ae4e1;hb=0e3de6438268c17083907e7410471d9ee497963f;hp=3e5f51d8f67ef454fa602f2d6755dfb036b88e65;hpb=89fbc5de53910554c7167b12c82cab8c5eb2dce6;p=lab.git diff --git a/misc/findcombinable.pl b/misc/findcombinable.pl index 3e5f51d..8d515d9 100755 --- a/misc/findcombinable.pl +++ b/misc/findcombinable.pl @@ -4,11 +4,17 @@ use strict; use warnings; use utf8; +use Encode; use Unicode::Normalize qw(NFC NFKC); +binmode STDOUT => 'encoding(utf8)'; +binmode STDERR => 'encoding(utf8)'; my $top = shift @ARGV || exit; if (! -d $top) { exit; } +my $utf8 = find_encoding("utf8"); +$top = $utf8->decode($top); + checkdir($top); sub match { @@ -17,9 +23,6 @@ sub match { if ($str ne NFC($str)) { return 1; } - if ($str ne NFKC($str)) { - return 1; - } return ''; } @@ -29,12 +32,12 @@ sub checkdir { print STDERR "checking '$target'\n"; opendir(my $dir, $target) || return $target; - my @entries = sort readdir($dir); + my @entries = sort grep { !m/^(\.|\.\.)$/g } readdir($dir); closedir($dir); my @dirs; while (my $entry = shift @entries) { - next if ($entry =~ /^\.+$/); + $entry = $utf8->decode($entry); if (match($entry)) { print "'$target/$entry' can be composed\n"; next;