X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/864adbb0287dc16f05e41f612a0f2835c9848d7b..1d1b3f6faefdc6666db120b3cbaf5c76a7dadcb6:/index.plp diff --git a/index.plp b/index.plp index ed49475..94a7788 100644 --- a/index.plp +++ b/index.plp @@ -125,6 +125,14 @@ sub escapeclass { return $_; } +my %keytrans = qw( + ^@ NUL ^a SOH ^b STX ^c ETX ^d EOT ^e ENQ ^f ACK ^g BEL + ^h BS ^i tab ^j LF ^k VT ^l FF ^m CR ^n SO ^o SI + ^p DLE ^q DC1 ^r DC2 ^s DC3 ^t DC4 ^u NAK ^v SYN ^w ETB + ^x CAN ^y EM ^z SUB ^[ ESC ^\ FS ^] GS ^^ RS ^_ US + ^? DEL +); + sub print_key { my ($mode, $key, $keyinfo) = @_; @@ -133,6 +141,7 @@ sub print_key { my ($desc, $flags, $mnem) = @$keyinfo if defined $keyinfo; defined $desc or $flags = $key eq '^0' ? 'ni' : 'no'; +# $key = $keytrans{$key} if defined $keytrans{$key}; my $keytxt = $mode . Entity($key) if $key ne '^0'; $keytxt .= $sign{arg} while $flags =~ s/ ?\barg\b//; # argument $keytxt .= "$sign{motion}" if $flags =~ s/ ?\bargm\b//; # motion argument @@ -141,6 +150,8 @@ sub print_key { ' 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"}; print qq{\t\t
  • $keytxt}; @@ -159,19 +170,17 @@ for (my $row = 0; $row <= $#$keyrows; $row++) { my $keycase = $keyrow->[$case]; @$keycase or next; - printf(qq{\t

    %s

    \n}, # XXX insert   here to fix msie<=6 - $mode eq '' ? '' : sprintf( - ' class="%s"', 'mode mode' . escapeclass($mode) - ), - sprintf('%s: %s', + printf "\t", $mode ne '' && sprintf( + ' class="%s"', 'mode mode' . escapeclass($mode) + ); + printf("

    %s: %s

    \n", # XXX insert   here to fix msie<=6 $modekeys->{desc} || "mode $mode", "$rowdesc[$row] row $casedesc[$case]" - ) ); - my $modeclass = 'keys'; - $modeclass .= ' lead' if defined $modekeys->{lead}; # leading command key shown - $modeclass .= " $casedesc[$case]" if defined $casedesc[$case]; - print qq{\t\t
      \n}; + my $caseclass = 'keys'; + $caseclass .= ' lead' if defined $modekeys->{lead}; # leading command key shown + $caseclass .= " $casedesc[$case]" if defined $casedesc[$case]; + print qq{\t\t
        \n}; print_key($modekeys->{lead}, $_, $modekeys->{$_}) for @$keycase; print qq{\t\t
      \n}; } # case @@ -223,13 +232,13 @@ for (my $row = 0; $row <= $#$keyrows; $row++) {
    • keyboard map is <:= $get{map} ? 'set to ' : '' :><:= $map :>
    • ascii mode is - <:= exists $get{ascii} ? 'forced ' : '' :><:= + <:= exists $get{ascii} && 'forced ' :><:= $ascii ? 'on' : 'off' :>
    • keys are <:= $showkeys ? 'always shown' : 'hidden if unassigned' :><:= - exists $get{keys} ? '' : ' by default' :> + exists $get{keys} || ' by default' :>
    • default style is - <:= defined $get{style} ? 'set to ' : '' :><:= $style :> + <:= defined $get{style} && 'set to ' :><:= $style :>