From: Mischa POSLAWSKY Date: Fri, 19 Mar 2010 00:14:24 +0000 (+0000) Subject: formatchar: highlight by unicode range if no digraphs X-Git-Tag: v1.3~28 X-Git-Url: http://git.shiar.nl/sheet.git/commitdiff_plain/e9cb855977ddc299c5ef1d74ce260e4ad4e21a08 formatchar: highlight by unicode range if no digraphs Marking up digraph properties makes no sense if digraphs are not shown. Fall back to exposing latin1 and bmp characters instead. --- diff --git a/Shiar_Sheet/FormatChar.pm b/Shiar_Sheet/FormatChar.pm index ba38035..656252c 100644 --- a/Shiar_Sheet/FormatChar.pm +++ b/Shiar_Sheet/FormatChar.pm @@ -6,7 +6,7 @@ use warnings; use Data::Dump 'pp'; use PLP::Functions 'EscapeHTML'; -our $VERSION = '1.01'; +our $VERSION = '1.02'; our $diinfo = do 'digraphs.inc.pl'; our %di = map { $diinfo->{$_}->[0] => $_ } grep { ref $diinfo->{$_} } @@ -83,9 +83,20 @@ sub cell { ($cell, $title, my $class, $mnem) = $self->glyphs_html($input); - if (defined $mnem) { - push @class, 'di-d'; # digraph - push @class, 'di-prop' if $class =~ /\bXz\b/; # unofficial + if ($self->{digraph}) { + if (defined $mnem) { + push @class, 'di-d'; # digraph + push @class, 'di-prop' if $class =~ /\bXz\b/; # unofficial + } + } + else { + my $codepoint = ord(substr $input, 0, 1); + if ($codepoint <= 0xFF) { + push @class, 'di-d'; # latin1 + } + elsif ($codepoint <= 0xD7FF) { + push @class, 'di-prop'; # bmp + } } if ($input =~ /[ -~]/) { @@ -100,12 +111,13 @@ sub cell { defined $title ? qq{ title="$title"} : '', @class ? sprintf(' class="%s"', join ' ', @class) : '', $html || '', - $cell eq '' ? ' ' : $cell, - $self->{digraph} && defined $mnem && length $mnem + $cell eq '' ? (' ', '') : ($cell, + $self->{digraph} && defined $mnem && length $mnem ? sprintf(' %s', EscapeHTML($mnem)) : $self->{unicode} + $cell =~ /^[^a-zA-Z]$/ > 0 ? sprintf(' %04X', 'value', ord $cell) - : '', + : '' + ), ); } diff --git a/unicode.plp b/unicode.plp index f506fb5..7149953 100644 --- a/unicode.plp +++ b/unicode.plp @@ -28,8 +28,12 @@ i^k or i^vu respectively in Vim. use Shiar_Sheet::FormatChar; my $glyphs = Shiar_Sheet::FormatChar->new; +if (exists $get{di}) { + $glyphs->{digraph} = defined $get{di} ? ! !$get{di} : 1; + $glyphs->{unicode} = 1; +} if (exists $get{q}) { - $glyphs->{unicode}--; + $glyphs->{unicode} = -1; $glyphs->{digraph}--; } @@ -207,8 +211,8 @@ $verbose ? (
ascii - digraph - proposed + <:= $glyphs->{digraph} ? 'digraph' : 'latin1' :> + <:= $glyphs->{digraph} ? 'proposed' : 'BMP' :> other unicode discouraged