X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/6b3439ac33bb88d613ac4a3670e14a2c673b3221..9c976dfa8a3cd5dc9ae2b3b9e3ae207ff666cab8:/Shiar_Sheet/FormatChar.pm diff --git a/Shiar_Sheet/FormatChar.pm b/Shiar_Sheet/FormatChar.pm index c0a4cb0..3d9b6fb 100644 --- a/Shiar_Sheet/FormatChar.pm +++ b/Shiar_Sheet/FormatChar.pm @@ -8,9 +8,9 @@ use utf8; use Data::Dump 'pp'; use PLP::Functions 'EscapeHTML'; -our $VERSION = '1.08'; +our $VERSION = '1.09'; -our $uc = do 'unicode-char.inc.pl'; +our $uc = do 'data/unicode-char.inc.pl'; sub new { my ($class) = @_; @@ -34,7 +34,7 @@ sub glyph_html { my ($class, $name, $mnem, $entity, $string) = @$info; my $cell = EscapeHTML($string || $char); - my $title = sprintf 'U+%04X%s', $codepoint, !!$name && " ($name)"; + my $title = sprintf 'U+%04X%s', $codepoint, !!$name && " $name"; $cell = "$cell" if $class and $class =~ /\bZs\b/; $cell = ' ' if $cell eq ''; @@ -61,6 +61,31 @@ sub glyph_cell { return sprintf('%s', $self->glyph_html($char)); } +sub glyph_level_univer { + my ($self, $input) = @_; + if ($input =~ /\p{age=unassigned}/) { + # check include for assignments after unicode 6.0 (perl v5.14) + state $agemap = do 'data/unicode-age.inc.pl'; + my $version = $agemap->{ord $input}; + return $version ? 'l2' : 'l1'; + } + elsif ($input =~ /^\p{in=1.1}*$/) { + return 'l5'; # first release 1993 + } + elsif ($input =~ /^\p{in=3.0}*$/) { + return 'l4'; # 20th century + } + elsif ($input =~ /^\p{in=4.1}*$/) { + return 'l4'; # over 10 years ago + } + elsif ($input =~ /^\p{in=6.0}*$/) { + return 'l3'; # before 2012 + } + else { + return 'l2'; # more recent + } +} + sub cell { my ($self, $input, $html) = @_; my (@class, $title, $cell, $mnem, $entity); @@ -81,33 +106,13 @@ sub cell { $input =~ s/^\\//; # escaped char ($cell, $title, my $class, $mnem, $entity) = $self->glyphs_html($input); - my $codepoint = ord $input; if ($self->{style} eq 'univer') { - if ($input =~ /\p{age=unassigned}/) { - # check include for assignments after unicode 6.0 (perl v5.14) - state $agemap = do 'unicode-age.inc.pl'; - my $version = $agemap->{$codepoint}; - push @class, $version ? 'l2' : 'l1'; - } - elsif ($input =~ /^\p{in=1.1}*$/) { - push @class, 'l5'; # first release 1993 - } - elsif ($input =~ /^\p{in=3.0}*$/) { - push @class, 'l4'; # 20th century - } - elsif ($input =~ /^\p{in=4.1}*$/) { - push @class, 'l4'; # over 10 years ago - } - elsif ($input =~ /^\p{in=6.0}*$/) { - push @class, 'l3'; # before 2012 - } - else { - push @class, 'l2'; # more recent - } + push @class, $self->glyph_level_univer($input); next; } + my $codepoint = ord $input; if ($self->{style} eq 'di') { if ($mnem and $mnem =~ /…/) { # incomplete representation, usually partial