charset: assume parent visibility
[sheet.git] / charset.plp
index 309139e940fa46ec54b39e1a2c039768cfe698a2..9d7375d8c7fa5e05d11af279a47adc3057a9493e 100644 (file)
@@ -137,18 +137,21 @@ sub tabinput {
 
                my @parents = @{ $INHERIT->{$input} || [] };
 
-               if (my ($parent, $part) = pairfirst { $visible->{$a} } @parents) {
+               if (my ($parent, $part) = pairfirst { exists $visible->{$a} } @parents) {
                        $row{parent} = $parent;
                        $params = $part;
+                       $_ eq $part or $params = 128 for $visible->{$parent} // ();
                }
-               elsif ($visible->{ascii}) {
-                       $row{parent} = $parents[0] || 'ascii';
+               elsif (exists $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};
        }
 
        if (defined $params and $params =~ m/^ (\d+) (-\d+)? /x) {
@@ -209,7 +212,7 @@ sub tabinput {
                        }
 
                        $visible->{ascii} =  # assume common base
-                       $visible->{ $row{set} } = 1;
+                       $visible->{ $row{set} } = undef;
                }
        }
        else {