X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/d060777e2e9e8a69dbee19936894cd62174871b6..e3e4c296dc5549aea747ecbd01366a372d304261:/charset.plp diff --git a/charset.plp b/charset.plp index d96ca45..9bdf363 100644 --- a/charset.plp +++ b/charset.plp @@ -68,6 +68,7 @@ my @request = map { $row{cell} = do 'charset-ucplanes.inc.pl' or Alert('Table data could not be read', $@ || $!); $colsize = 8; + $cols *= 2; } elsif ($row{set} = Encode::resolve_alias($input)) { if ($row{set} eq 'Internal') { @@ -121,8 +122,18 @@ sub range_cell { $rest = $len if $len < $rest; #TODO: optimise if ($len -= $rest) { # continued on new row - $table->{$offset + $colsize*$rest} //= [$len*$colsize, "$class joinu", $name, $title]; - $name = ''; + my @next = ($len * $colsize, "$class joinu"); + if ($len > $rest) { + # minority remains + push @next, $name, $title; + $title ||= $name; + $name = ''; + } + else { + # minority on next row + push @next, '"', $title || $name; + } + $table->{$offset + $colsize*$rest} //= \@next; $class .= ' joind'; } $len = $rest; @@ -163,10 +174,6 @@ for my $row (@request) { for my $lsb (0 .. $cols - 1) { my $val = ( ($msb * $cols) + $lsb ) * $colsize; if ($row->{cell}) { - if (ref $row->{cell} eq 'CODE') { - print $row->{cell}->($val); - next; - } print range_cell($row->{cell}, $val); next; }