X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/a84b651b70f484379de8ac84a2abac91e59c1a6e..378d119f5791fea807f36749ce9ecb5a5c60952e:/Shiar_Sheet/Keyboard.pm diff --git a/Shiar_Sheet/Keyboard.pm b/Shiar_Sheet/Keyboard.pm index f56437f..cca8333 100644 --- a/Shiar_Sheet/Keyboard.pm +++ b/Shiar_Sheet/Keyboard.pm @@ -5,11 +5,13 @@ use warnings; no warnings 'uninitialized'; # save some useless checks for more legible code use Carp; -our $VERSION = '1.00'; +our $VERSION = 'v1.05'; -my @casedesc = qw(ctrl shift); +my @casedesc = (undef, qw/shift ctrl meta/, 'shift meta'); my @rowdesc = qw(numeric top home bottom); my %keyrows = do 'keys.inc.pl'; +# add first two cases of each row again with each char prepended by + (alt) +push @$_, map { [map {"+$_"} @$_] } @$_[0,1] for map {@$_} values %keyrows; my %keytrans = qw( ^@ NUL ^a SOH ^b STX ^c ETX ^d EOT ^e ENQ ^f ACK ^g BEL @@ -45,6 +47,7 @@ sub map { sub escapeclass { local $_ = shift; s/\^/_c/g; + s/\+/_m/g; s/\[/_sbo/g; s/\]/_sbc/g; s/^$/_/; @@ -63,7 +66,7 @@ sub keyunalias { my $self = shift; my ($key, $ancestry) = @_; - $key =~ s/(\S*?)(\^?\S)($|\s.*)/$2/; + $key =~ s/(\S*?)(\+?\^?\S)($|\s.*)/$2/; my $mode = $1; my $keyinfo = $self->{keys}->{$mode}->{$key}; @@ -84,47 +87,57 @@ sub print_key { # $key = $keytrans{$key} if defined $keytrans{$key}; my $keytxt = $mode . escapehtml($key) if $key ne '^0'; - $keytxt .= $self->{sign}->{arg} while $flags =~ s/ ?\barg\b//; # argument + $keytxt .= $self->{sign}->{$1} while $flags =~ s/(?:^| )(arg[a-ln-z]?)\b//; # arguments $keytxt .= "$self->{sign}->{motion}" if $flags =~ s/ ?\bargm\b//; # motion argument $keytxt =~ s{\^(?=.)}{^}; # element around ctrl-identifier + $keytxt =~ s{\+(?=.)}{+}; # meta + my $keyhint = defined($mnem) && qq{ title="$mnem"}; + $keytxt = "$keytxt"; + $keytxt .= ' '.$desc if defined $desc; + $keytxt = qq{$keytxt} if $flags =~ s/ ?\blink(\S*)//; my $onclick = $flags =~ s/ ?\bmode(\S*)// && defined $self->{keys}{$1} && sprintf( ' onclick="setmode(%s)"', $1 eq '' ? '' : sprintf(q{'mode%s'}, escapeclass($1)) ); - $onclick .= sprintf(q{ onclick="document.location='%s'"}, $1) - if $flags =~ s/ ?\blink(\S*)//; - my $keyhint = defined($mnem) && qq{ title="$mnem"}; + $flags .= ' chr'.ord(substr $key, -1) if $key ne '^0'; - print qq{\t\t
  • $keytxt}; - print ' ', $desc if defined $desc; + print qq{\t\t
  • $keytxt}; print "\n"; } sub print_rows { my $self = shift; - my $static = shift; - my @moderows = $static ? split(/\s+/, $static) : sort keys %{ $self->{keys} }; + my %moderows = ( + -DEFAULT => !@_ ? '' : split(/(?:\s*([^=\s]*)=\s*)/, shift), + # plus specific mode overrides prefixed by '=' + ); + my $defrows = shift || [2, 1, 0]; + my @modes = sort keys %{ $self->{keys} }; for (my $row = 0; $row <= $#{ $keyrows{$self->{map}} }; $row++) { my $keyrow = $keyrows{$self->{map}}->[$row]; - my @caserows = 0 .. $#$keyrow; print qq{
  • \n}; } # case - } # mode + } # submode + + } # basemode print qq{\t\n}; } # row } @@ -163,13 +178,13 @@ Shiar_Sheet::Keyboard - Output HTML for key sheets =head1 DESCRIPTION -Used by http://sheet.shiar.net to display keyboard sheets. +Used by http://sheet.shiar.nl to display keyboard sheets. Assumes specific stylesheets and javascript from this site, so probably not of much use elsewhere. =head1 AUTHOR -Mischa POSLAWSKY +Mischa POSLAWSKY =head1 LICENSE