From ef1048178fa3bc0d43f4e2bbbee58530f8b0e55c Mon Sep 17 00:00:00 2001 From: Mischa POSLAWSKY Date: Tue, 16 Sep 2008 02:43:17 +0000 Subject: [PATCH] unicode: table improvements Updated glyph table rendering code, notably featuring: - cells spanning multiple columns for the IPA table; - showing Unicode value if there's no digraph known. --- unicode.plp | 141 +++++++++++++++++++++++++++++++--------------------- 1 file changed, 84 insertions(+), 57 deletions(-) diff --git a/unicode.plp b/unicode.plp index 4d48bb4..7c05183 100644 --- a/unicode.plp +++ b/unicode.plp @@ -48,14 +48,20 @@ td { vertical-align: top; margin: 0; padding: 0; + width: 1.6em; } small { font-size: 50%; display: block; - width: 3.2em; +} +small.digraph { background: #888; color: #FFF; } +small.value { + background: #CCC; + color: #666; +} td.empty { background: #DDD; @@ -88,79 +94,100 @@ sub quote { sub table { my ($width, $digraphs, $rowheads, $colheads) = @_; - my @cells; - push @cells, sprintf '%s%s', - $di{ord $_} && $diinfo->{$di{ord $_}}->[1], - $_ eq '-' ? ' class="empty"' : $_ eq '=' ? ' class="reserved"' : '', - $_ eq '-' || $_ eq '=' ? ' ' : quote($_), - $di{ord $_} && sprintf(' %s', $di{ord $_}) - for @$digraphs; - - if ($rowheads) { - splice @cells, $_ * $width, 0, ''.($rowheads->[$_] || ' ') - for reverse 0 .. $#cells / $width; - $width++; - } - my @rows; - push @rows, sprintf '%s', join '', splice @cells, 0, $width, () - while @cells; + + my $colspan = 1; + for my $cell (@$digraphs) { + my $class; + if ($cell eq '.') { + push @rows, ''; + $rows[-1] .= ''.(shift @$rowheads || ' ') if $rowheads; + next; + } + elsif ($cell eq '>') { + $colspan++; + next; + } + elsif ($cell =~ s/^-//) { + $class = 'empty'; + } + elsif ($cell eq '=') { + $class = 'reserved'; + $cell = ''; + } + + my $code = join '', map { $di{ord $_} || '' } split //, $cell; + my $name = $diinfo->{$code}->[1]; + + $rows[-1] .= sprintf('%s%s', + defined $name ? qq{ title="$name"} : '', + defined $class ? qq{ class="$class"} : '', + $colspan > 1 && qq{ colspan="$colspan"}, + $cell eq '' ? ' ' : quote($cell), + $code ne '' ? sprintf(' %s', quote($code)) + : length($cell) == 1 && $cell !~ /[a-z]/ + ? sprintf(' %04X', 'value', ord $cell) + : '', + ); + + $colspan = 1; + } if ($colheads) { unshift @rows, sprintf '%s', join '', - map { sprintf '%s', split(/:/, $colheads->[$_], 2) } - 0 .. $width-2; + map { sprintf '%s', split(/:/, $_, 2) } + @$colheads } - return sprintf "%s
\n", join '', @rows; + return sprintf "\n%s
\n", join '', map {"$_\n"} @rows; } print "

Arrows

\n\n"; print table(@$_) for ( - [ 4 => [qw{↖ ↑ ↗ ↔ ← - → ↕ ↙ ↓ ↘ -}]], - [ 4 => [qw{⇖ ⇑ ⇗ ⇔ ⇐ - ⇒ ⇕ ⇘ ⇓ ⇙ -}]], - [ 3 => [qw{◤ ▲ ◥ ◀ ◆ ▶ ◣ ▼ ◢}]], - [ 3 => [qw{◸ △ ◹ ◁ ◇ ▷ ◺ ▽ ◿}]], + [ 4 => [qw{. ↖ ↑ ↗ ↔ . ← - → ↕ . ↙ ↓ ↘ -}]], + [ 4 => [qw{. ⇖ ⇑ ⇗ ⇔ . ⇐ - ⇒ ⇕ . ⇘ ⇓ ⇙ -}]], + [ 3 => [qw{. ◤ ▲ ◥ . ◀ ◆ ▶ . ◣ ▼ ◢}]], + [ 3 => [qw{. ◸ △ ◹ . ◁ ◇ ▷ . ◺ ▽ ◿}]], ); print "

Line drawing

\n\n"; print table(@$_) for ( - [ 4 => [qw{┌ ┬ ┐ ─ ├ ┼ ┤ │ └ ┴ ┘ -}]], - [ 4 => [qw{┏ ┳ ┓ ━ ┣ ╋ ┫ ┃ ┗ ┻ ┛ -}]], - [ 3 => [qw{┍ ┯ ┑ ┝ ┿ ┥ ┕ ┷ ┙}]], - [ 3 => [qw{┎ ┰ ┒ ┠ ╂ ┨ ┖ ┸ ┚}]], -# [ 4 => [qw{╔ ╦ ╗ ═ ╠ ╬ ╣ ║ ╚ ╩ ╝ -}]], -# [ 3 => [qw{╒ ╤ ╕ ╞ ╪ ╡ ╘ ╧ ╛}]], -# [ 3 => [qw{╓ ╥ ╖ ╟ ╫ ╢ ╙ ╨ ╜}]], + [ 4 => [qw{. ┌ ┬ ┐ ─ . ├ ┼ ┤ │ . └ ┴ ┘ -}]], + [ 4 => [qw{. ┏ ┳ ┓ ━ . ┣ ╋ ┫ ┃ . ┗ ┻ ┛ -}]], + [ 3 => [qw{. ┍ ┯ ┑ . ┝ ┿ ┥ . ┕ ┷ ┙}]], + [ 3 => [qw{. ┎ ┰ ┒ . ┠ ╂ ┨ . ┖ ┸ ┚}]], +# [ 4 => [qw{. ╔ ╦ ╗ ═ . ╠ ╬ ╣ ║ . ╚ ╩ ╝ -}]], +# [ 3 => [qw{. ╒ ╤ ╕ . ╞ ╪ ╡ . ╘ ╧ ╛}]], +# [ 3 => [qw{. ╓ ╥ ╖ . ╟ ╫ ╢ . ╙ ╨ ╜}]], ); print "

Signs

\n\n"; print table(@$_) for ( - [ 3 => [qw{▘ ▀ ▝ ▌ █ ▐ ▖ ▄ ▗ ░ ▒ ▓}]], - [ 3 => [qw{□ ▣ ■ ▤ ▦ ▥ ▧ ▩ ▨}]], - [ 4 => [qw{♠ ♡ ♢ ♣ ♤ ♥ ♦ ♧}]], - [10 => [qw{☼ ☿ ♀ ♁ ♂ ♃ ♄ ♅ ♆ ♇}]], # solar -# [12 => [qw{♈ ♉ ♊ ♋ ♌ ♍ ♎ ♏ ♐ ♑ ♒ ♓}]], # zodiac - [ 8 => [qw{¤ ¢ ₥ € £ ₨ $ ¥ ₫ ₭ ₦ ₱ ₧ ₮ ₩ ₪}]], + [ 3 => [qw{. ▘ ▀ ▝ . ▌ █ ▐ . ▖ ▄ ▗ . ░ ▒ ▓}]], + [ 3 => [qw{. □ ▣ ■ . ▤ ▦ ▥ . ▧ ▩ ▨}]], + [ 4 => [qw{. ♠ ♡ ♢ ♣ . ♤ ♥ ♦ ♧}]], + [ 5 => [qw{. ☼ ☿ ♀ ♁ ♂ ♃ ♄ ♅ ♆ ♇}]], # solar +# [12 => [qw{. ♈ ♉ ♊ ♋ ♌ ♍ ♎ ♏ ♐ ♑ ♒ ♓}]], # zodiac + [ 8 => [qw{. ¤ ¢ ₥ € £ ₨ $ ¥ . ₫ ₭ ₦ ₱ ₧ ₮ ₩ ₪}]], ); print "

IPA

\n\n"; print table(@$_) for ( [ 12 => [qw{ - p t - ʈ - c k q - = ʡ ʔ - b d - ɖ - ɟ ɡ ɢ - = - = - m ɱ - n - ɳ ɲ ŋ ɴ = = = - ʙ - - r - - - = ʀ = я = - - ⱱ - ɾ - ɽ - = ɢ̆ = - = - ɸ f θ s ʃ ʂ ç x χ ħ ʜ h - β v ð z ʒ ʐ ʝ ɣ ʁ ʕ ʢ ɦ - = = - ɬ - - - - - = = = - = = - ɮ - - - - - = = = - - ʋ - ɹ - ɻ j ɰ - - - = - = = - l - ɭ ʎ ʟ - = = = - ʘ - ǀ ǁ ǃ - ǂ - - = = = - ɓ - ɗ - - - ʄ ɠ ʛ - - - + . p p̪ > > t ʈ c k q = ʡ ʔ + . b b̪ > > d ɖ ɟ ɡ ɢ = - = + . m ɱ > > n ɳ ɲ ŋ ɴ = = = + . ʙ - > > r - - = ʀ = -я = + . - ⱱ > > ɾ ɽ - = ɢ̆ = - = + . ɸ f θ s ʃ ʂ ç x χ ħ ʜ h + . β v ð z ʒ ʐ ʝ ɣ ʁ ʕ ʢ ɦ + . = = > > ɬ - - - - = = = + . = = > > ɮ - - - - = = = + . - ʋ > > ɹ ɻ j ɰ - - - = + . = = > > l ɭ ʎ ʟ - = = = + . ʘ - ǀ ǁ ǃ -‼ ǂ - - = = = + . ɓ ɗ̪ > > ɗ -ᶑ ʄ ɠ ʛ = = = }], [ 'Plosive', @@ -183,13 +210,13 @@ print table(@$_) for ( ], [ 6 => [qw{ - i y ɨ ʉ ɯ u - - ɪ ʏ - ʊ - - e ø ɘ ɵ ɤ o - - - ə - - - - ɛ œ ɜ ɞ ʌ ɔ - æ - ɐ - - - - a ɶ - - ɑ ɒ + . i y ɨ ʉ ɯ u + . - ɪ ʏ - ʊ - + . e ø ɘ ɵ ɤ o + . - - ə - - - + . ɛ œ ɜ ɞ ʌ ɔ + . æ - ɐ - - - + . a ɶ - - ɑ ɒ }], [qw{Close Near-close Close-mid Mid Open-mid Near-open Open}], [map {substr($_, 0, 1).':'.$_, substr($_, 0, 1)." r:$_ rounded"} qw{Front Central Back}] -- 2.30.0