X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/6e6a65b81dcaf4c6e82d0ed14fce1a3bee50ae1d..23b5f682cff553f97e80951ed12f4097bfed4c8f:/unicode.plp diff --git a/unicode.plp b/unicode.plp index 5f2c576..92f9a01 100644 --- a/unicode.plp +++ b/unicode.plp @@ -11,7 +11,7 @@ Html({ unicode glyph char character reference common ipa symbol sign mark table digraph '], stylesheet => [qw'light dark mono circus red'], - data => [qw'digraphs.inc.pl unicode.inc.pl'], + data => [qw'unicode-table.inc.pl unicode-char.inc.pl'], }); :> @@ -38,54 +38,25 @@ if (exists $get{q}) { } if (exists $get{html}) { $glyphs->{anno} = ['html', 'xml']; + $glyphs->{style} = 'html'; } our $verbose = exists $get{v}; -my $tables = do 'unicode.inc.pl' or die $@ || $!; - -$glyphs->print(map { - my $_ = /(.*)\?(.*)/ ? ($verbose ? $2 : $1) : $_; - if (/[A-Z]/) { - $_; - } - else { - state $group; - $group = $1 if s{^([^/]+)/}{}; - if (s/=(.*)//) { - my @select = split /=/, $1; - my $table = $tables->{$group}->{$_}; - my $rowlen; - for ($rowlen = 1; $rowlen++; $rowlen <= $#$table) { - last if $table->[$rowlen] =~ /\./; - } - my @cells = map { - my $end = (s/-(.+)?// ? ($1 // @$table / $rowlen - 1) : $_) + 1; - $_ * $rowlen .. $end * $rowlen - 1; - } @select; - [ @$table[@cells] ]; - } - else { - $tables->{$group}->{$_}; - } - } -} qw{ +my @config = qw( Popular punctuation/quoting - common + common=-5?common symbols/binary?symbols/binary=-5 latin/sample=-1 - sample=2-3 + ?sample=2- ?uncommon punctuation/version punctuation/marks - math/size - equal - set - logic + spacing Symbols symbols/currency - cards + cards=-3?cards ?chess signs1 communic=0?communic @@ -93,14 +64,21 @@ $glyphs->print(map { signs2 Signs solar - zodiac=0?zodiac - Key commands + zodiac=0-1=3?zodiac + Key_commands keys/spacing editing modifier control command + android + ps ?player + Mathematics + math/size + equal + set + logic Arrows arrows/single double @@ -111,7 +89,7 @@ $glyphs->print(map { whitetri ?-large ?-heavy - Line drawing + Line_drawing lines/double doubleh doublev @@ -137,7 +115,48 @@ $glyphs->print(map { ?hiraderiv ?kata ?kataderiv -}); +); + +splice @config, 4, 2, qw( + latin/vowels=-5?latin/vowels + westeuro + ?easteuro +) if exists $get{html}; + +$_ and m{/*+(.+)} and @config = split /[ ]/, $1 for $ENV{PATH_INFO}, $get{q}; + +my $tables = do 'unicode-table.inc.pl' or die $@ || $!; + +$glyphs->print(map { + my $_ = /(.*)\?(.*)/ ? ($verbose ? $2 : $1) : $_; + if (!$_) { + (); + } + elsif (/[A-Z]/) { + tr/_/ /; + $_; + } + else { + state $group; + $group = $1 if s{^([^/]+)/}{}; + my @select = s/=(.*)// ? split(/=/, $1) : (); + my $table = $tables->{$group}->{$_} + or die "Unknown table specified: $group/$_"; + + if (@select) { + my $rowlen; + for ($rowlen = 1; $rowlen++; $rowlen <= $#$table) { + last if $table->[$rowlen] =~ /\./; + } + my @cells = map { + my $end = (s/-(.+)?// ? ($1 // @$table / $rowlen - 1) : $_) + 1; + $_ * $rowlen .. $end * $rowlen - 1; + } @select; + $table = [ @$table[@cells] ]; + } + $table; + } +} @config); :>