charset: exceptionally inherit MacCroatian from MacRomanian
[sheet.git] / charset.plp
index 9d7375d8c7fa5e05d11af279a47adc3057a9493e..5e16116a412cbb606dc5d0e6c1602175b1833bdd 100644 (file)
@@ -137,21 +137,21 @@ sub tabinput {
 
                my @parents = @{ $INHERIT->{$input} || [] };
 
-               if (my ($parent, $part) = pairfirst { exists $visible->{$a} } @parents) {
+               if (my ($parent, $part) = pairfirst { defined $visible->{$a} } @parents) {
                        $row{parent} = $parent;
                        $params = $part;
-                       $_ eq $part or $params = 128 for $visible->{$parent} // ();
+                       $params = 128 unless $visible->{$parent}
+                               or ($input eq 'MacCroatian' and defined $visible->{MacRomanian});
                }
-               elsif (exists $visible->{ascii}) {
+               elsif (defined $visible->{ascii}) {
                        $row{parent} = $parents[0];
                        $params = $parents[1] || 128;
-                       exists $visible->{$_} or $visible->{$_} = $params for $row{parent};
                        $params = 128 if $params >= 128;  # ascii offset at most
                }
                elsif (@parents) {
                        $row{parent} = $parents[0];
                }
-                       exists $visible->{$_} or $visible->{$_} = $params // 0 for $row{parent};
+               $visible->{$_} //= 0 for $row{parent};
        }
 
        if (defined $params and $params =~ m/^ (\d+) (-\d+)? /x) {
@@ -212,7 +212,7 @@ sub tabinput {
                        }
 
                        $visible->{ascii} =  # assume common base
-                       $visible->{ $row{set} } = undef;
+                       $visible->{ $row{set} } = 1;
                }
        }
        else {