X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/137be49b9a79623be00aa0cb1f416599949b1cf9..6ae2e63f9d7f8944b507b7396686a733c6422739:/unicode.plp diff --git a/unicode.plp b/unicode.plp index 3173cfd..cdcaa2a 100644 --- a/unicode.plp +++ b/unicode.plp @@ -42,38 +42,7 @@ if (exists $get{html}) { our $verbose = exists $get{v}; -my $tables = do 'unicode.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; - } -} qw{ +my @config = qw( Popular punctuation/quoting common @@ -143,7 +112,42 @@ $glyphs->print(map { ?hiraderiv ?kata ?kataderiv -}); +); + +$_ and m{/*+(.+)} and @config = split /[ ]/, $1 for $ENV{PATH_INFO}, $get{q}; + +my $tables = do 'unicode.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); :>