Html({
title => 'latin alphabet cheat sheet',
- version => 'v1.1',
+ version => '1.5',
description => [
],
keywords => [qw'
latin roman alphabet script letter unicode font glyph abc
- writing comparison character sample test language spelling
- cursive fraktur blind deaf
+ code encoding spelling symbol writing comparison character
+ secret cursive fraktur blind braille morse deaf asl hand
+ barcode bar color semaphore flag
'],
- stylesheet => [qw'light dark red'],
+ stylesheet => [qw( light dark red mono )],
data => ['writing-latn.inc.pl'],
});
:>
<style>
- @font-face {
- font-family: Suetterlin; /* R. G. Arens */
- src: url("/suetterlin.ttf");
+ td svg {
+ vertical-align: middle;
}
- @font-face {
- font-family: Gallaudet;
- src: url("/gallaudet.ttf");
+ svg path:not([fill]) {
+ stroke: currentColor;
+ fill: none;
+ }
+ svg circle:not([fill]) {
+ fill: currentColor;
+ }
+
+ .sample {
+ text-align: left;
+ padding: 1px 0.3em;
+ }
+ td.sample {
+ width: auto;
+ }
+ th {
+ white-space: nowrap; /* prevent resize by sample */
}
- .glyphs tr:first-child+tr td { font-family: Suetterlin }
- .glyphs tr:first-child+tr+tr td { font-family: Gallaudet }
</style>
<h1>Latin alphabet</h1>
-<p>Also see <a href="/writing">other alphabets</a>
-and <a href="/unicode">common chars</a>.</p>
+<p id=intro>Variant encodings of the common ASCII (latin, roman,
+or <span title="fuck yeah!">'mercan</span>) letters A–Z.
+Also see <a href="/writing">related alphabets</a>
+and <a href="/chars/abc">font comparison</a>.</p>
-<div class="-diinfo">
+<div>
<:
-use Shiar_Sheet::FormatChar;
-my $glyphs = Shiar_Sheet::FormatChar->new;
-unless (exists $get{v}) {
- $glyphs->{unicode}--;
- $glyphs->{anno} = [];
- $glyphs->{style} = 0;
-}
-
-my %scriptname = (
- latn => 'Latin',
- latfsuet => 'Sütterlin',
- ase => '<abbr title="American Sign Lanugage">ASL</abbr> shapes',
- brai => 'Braille',
- morse => 'Morse',
- tap => 'Tap code',
-);
+use List::Util qw( pairs );
my @table = do 'writing-latn.inc.pl';
if ($! or $@) {
- printf "<p class=error>Table data not found: <em>%s</em>.</p>\n", $@ || $!;
+ Alert("Table data not found", $@ || $!);
}
else {
- print $glyphs->table([map {
- ref $_ ne 'ARRAY' ? ".>$scriptname{$_}"
- : exists $get{uc} ? map {uc} @$_ : @$_
- } @table]);
+ say '<style>';
+ for my $row (pairs @table) {
+ my ($id, $info) = @{$row};
+ my $style = $info->{style} or next;
+ ref $style or $style = [$style];
+ say "\t", !/^@/ && "#$id ", $_ for @{$style};
+ }
+ say "</style>\n";
+
+ my %VOWELCOLS = (map { ($_ => 1) } 0, 4, 8, 14, 20, 24);
+ say '<table class="glyphs">';
+ say '<thead><tr><th># <small>ASCII − 64</small>';
+ print '<td>', $_ for 1 .. 26;
+ say '</thead>';
+
+ for my $row (pairs @table) {
+ my ($id, $info) = @{$row};
+
+ printf '<tr id="%s">', $id;
+ my $th = 'th';
+ $th .= sprintf ' title="%s"', $_ for $info->{title} || ();
+ say "<$th>", $info->{name} // ucfirst $id;
+
+ my $colspan = 1;
+ my $col = 0;
+ for (@{ $info->{list} }) {
+ $col++;
+ if ($_ eq '>') {
+ $colspan++;
+ next;
+ }
+ my @class;
+ push @class ,'l0' if $VOWELCOLS{$col - $colspan};
+ push @class, $_ ? 'ex' : 'u-invalid' if s/^-//;
+
+ print "\t<td";
+ if ($col > 26) {
+ # special character for sample generation
+ print ' hidden'; # sample only
+ }
+ else {
+ print ' title=', chr($col + ord('A') - $colspan);
+ }
+ if ($colspan > 1) {
+ print " colspan=$colspan";
+ $colspan = 1;
+ }
+ printf ' class="%s"', "@class" if @class;
+ print '>';
+ say;
+ }
+ }
+ say "</table>\n";
}
-print "</div>\n";
+:></div>
+
+<script type="text/javascript" src="/latinsample.js"></script>
+<script type="text/javascript"><!--
+ prependinput(document.getElementById('intro'));
+//--></script>