From 126777bc019a54afb4ec51299f2cf9d2841698aa Mon Sep 17 00:00:00 2001 From: Pascal Rigaux Date: Wed, 25 Apr 2007 12:26:16 +0000 Subject: re-sync after the big svn loss --- perl-install/install/share/kmap2bkmap | 39 +++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100755 perl-install/install/share/kmap2bkmap (limited to 'perl-install/install/share/kmap2bkmap') diff --git a/perl-install/install/share/kmap2bkmap b/perl-install/install/share/kmap2bkmap new file mode 100755 index 000000000..58505dda0 --- /dev/null +++ b/perl-install/install/share/kmap2bkmap @@ -0,0 +1,39 @@ +#!/usr/bin/perl + +use lib ".."; +use c; + +my $KMAP_MAGIC = 0x8B39C07F; + +BEGIN { @ARGV == 1 or die "usage: kmap2bkmap \n" } + +# load unicode keymap +my $unimap = "$ARGV[0]" . ".uni"; +system("sudo loadkeys $unimap") == 0 or die; +open F, "dumpkeys -n -f |"; + =~ /^keymaps\s+(.*)/ or die; +foreach (split ',', $1) { + my @l = /(\d+)-(\d+)/; + my ($i, $j) = @l ? @l : ($_,$_); + $keymaps[$_] = 1 foreach $i .. $j; +} + +print pack("I", $KMAP_MAGIC); +print map { pack "i", $keymaps[$_] || 0 } 0 .. c::MAX_NR_KEYMAPS()-1; + +foreach () { + s/\+0x/0x/g; + my ($keycode, $key, undef, @l) = split; + $keycode eq 'keycode' or next; + my $i = 0; + $L[$i++][$key] = hex $_ foreach @l; +} +close F or die "dumpkeys failed"; + +foreach (@L) { + foreach my $i (0 .. c::NR_KEYS()-1) { + print pack "s", defined $_->[$i] ? $_->[$i] : 0x200; + } +} + +exit 0; -- cgit v1.2.1