Code cleanup to map non-alphabetic characters in %rows instead of @rows.
--- /dev/null
+use utf8;
+my @az = ('A'..'Z', 'a'..'z');
+my @letters = qw(
+ Å ı Ç ð ´ ̉ ˝ ̣ ˆ ½ Þ ¾ ˜ Ø ∏ Œ ‰ / ˇ ¨ ◊ „ ˛ ¼ ¸
+ å ∫ ç ∂ ́ ƒ © ˙ ̂ ∆ ° ¬ µ ̃ ø π œ ® ß † ̈ √ ∑ ≈ ¥ Ω
+);
+our %rows = map {
+ $az[$_] => $letters[$_]
+} 0 .. $#az;
+
++{
+ %{ do 'keyboard.eng.inc.pl' },
+ version => '1.2',
+}
use utf8;
-my @usintrows = (
- [ 'a' .. 'z'],
- [qw(Á B ¢ Ð É F G H Í J Œ Ø µ Ñ Ó Ö Ä ® § Þ Ú V Å X Ü Æ)],
- [qw(á b © ð é f g h í j œ ø µ ñ ó ö ä ® ß þ ú v å x ü æ)],
- [qw(Å ı Ç ð ´ ̉ ˝ ̣ ˆ ½ Þ ¾ ˜ Ø ∏ Œ ‰ / ˇ ¨ ◊ „ ˛ ¼ ¸)],
- [qw(å ∫ ç ∂ ́ ƒ © ˙ ̂ ∆ ° ¬ µ ̃ ø π œ ® ß † ̈ √ ∑ ≈ ¥ Ω)],
-);
-our @rows = (
- map {
- my $c = $_;
- [ map { $usintrows[$_]->[$c] } 0 .. 2 ]
- } 0 .. $#{ $usintrows[0] }
+my @az = ('A'..'Z', 'a'..'z');
+my @letters = qw(
+ Á B ¢ Ð É F G H Í J Œ Ø µ Ñ Ó Ö Ä ® § Þ Ú V Å X Ü Æ
+ á b © ð é f g h í j œ ø µ ñ ó ö ä ® ß þ ú v å x ü æ
);
+our %rows = map {
+ $az[$_] => $letters[$_]
+} 0 .. $#az;
+{
%{ do 'keyboard.eng.inc.pl' },
use Text::Unidecode qw( unidecode );
{
- rows => [0],
+ rows => [0, 1],
def => {
'' => {
map {
- my @row = @{$_};
+ my $v = $rows{$_};
my $class = (
- !defined $row[2] || $row[0] eq $row[2] ? 1 # identical
- : $row[2] =~ /\A\p{Mn}+\z/ ? 8 # combining accent
- : NFKD($row[2]) =~ $row[0] ? 2 # decomposed equivalent
- : $row[2] =~ /^\p{Latin}/ ? 4 # latin script
- : unidecode($row[2]) =~ /^\W*\Q$row[0]/ ? 5 # transliterated
+ !defined $v || $_ eq $v ? 1 # identical
+ : $v =~ /\A\p{Mn}+\z/ ? 8 # combining accent
+ : NFKD($v) =~ $_ ? 2 # decomposed equivalent
+ : $v =~ /^\p{Latin}/ ? 4 # latin script
+ : unidecode($v) =~ /^\W*\Q$_/ ? 5 # transliterated
: 7
);
- $row[0] => "g$class"
- } @rows
+ $_ => "g$class"
+ } keys %rows
},
},
- key => {
- map {
- $_->[0] => "$_->[1]<br>$_->[2]"
- } @rows
- },
+ key => \%rows,
flag => {
g1 => ['unaltered', "same results as without modifier"],
g2 => ['accented', "decomposes to the original letter with a combining accent"],