]> git.ipfire.org Git - thirdparty/ipxe.git/commitdiff
[console] Treat dead keys as producing their ASCII equivalents
authorMichael Brown <mcb30@ipxe.org>
Tue, 15 Feb 2022 11:28:57 +0000 (11:28 +0000)
committerMichael Brown <mcb30@ipxe.org>
Tue, 15 Feb 2022 13:37:41 +0000 (13:37 +0000)
Treat dead keys in target keymaps as producing the closest equivalent
ASCII character, since many of these characters are otherwise
unrepresented on the keyboard.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
15 files changed:
src/hci/keymap/keymap_al.c
src/hci/keymap/keymap_cf.c
src/hci/keymap/keymap_cz.c
src/hci/keymap/keymap_de.c
src/hci/keymap/keymap_dk.c
src/hci/keymap/keymap_es.c
src/hci/keymap/keymap_et.c
src/hci/keymap/keymap_fi.c
src/hci/keymap/keymap_fr.c
src/hci/keymap/keymap_hu.c
src/hci/keymap/keymap_it.c
src/hci/keymap/keymap_nl.c
src/hci/keymap/keymap_no.c
src/hci/keymap/keymap_pt.c
src/util/genkeymap.py

index b68b988781e87711310f29ea7cfd7dbbb4cc0616..4d279171f6282e9abcc57d1744378fb3d3b43b11 100644 (file)
@@ -37,7 +37,9 @@ static struct keymap_key al_basic[] = {
 
 /** "al" AltGr remapping */
 static struct keymap_key al_altgr[] = {
+       { 0x30, 0x7e }, /* '0' => '~' */
        { 0x31, 0x7e }, /* '1' => '~' */
+       { 0x34, 0x7e }, /* '4' => '~' */
        { 0x37, 0x60 }, /* '7' => '`' */
        { 0, 0 }
 };
index 09242ee6f4f72ad6df9041de12ffda86a664f10c..434e3383c08a6afddf64ac11b9b65fdbe54c3a36 100644 (file)
@@ -12,13 +12,17 @@ FILE_LICENCE ( PUBLIC_DOMAIN );
 
 /** "cf" basic remapping */
 static struct keymap_key cf_basic[] = {
+       { 0x22, 0x60 }, /* '"' => '`' */
        { 0x23, 0x2f }, /* '#' => '/' */
+       { 0x27, 0x60 }, /* '\'' => '`' */
        { 0x3c, 0x27 }, /* '<' => '\'' */
        { 0x3e, 0x2e }, /* '>' => '.' */
        { 0x40, 0x22 }, /* '@' => '"' */
+       { 0x5b, 0x5e }, /* '[' => '^' */
        { 0x5c, 0x3c }, /* '\\' => '<' */
        { 0x5e, 0x3f }, /* '^' => '?' */
        { 0x60, 0x23 }, /* '`' => '#' */
+       { 0x7b, 0x5e }, /* '{' => '^' */
        { 0x7c, 0x3e }, /* '|' => '>' */
        { 0x7e, 0x7c }, /* '~' => '|' */
        { 0, 0 }
@@ -26,6 +30,7 @@ static struct keymap_key cf_basic[] = {
 
 /** "cf" AltGr remapping */
 static struct keymap_key cf_altgr[] = {
+       { 0x27, 0x7b }, /* '\'' => '{' */
        { 0x32, 0x40 }, /* '2' => '@' */
        { 0x3b, 0x7e }, /* ';' => '~' */
        { 0x60, 0x5c }, /* '`' => '\\' */
index cce686d9ab9b29f57f9a1bd12cd175e230157a72..fb072b11777a875059b9ff58c656663637870c32 100644 (file)
@@ -24,6 +24,7 @@ static struct keymap_key cz_basic[] = {
        { 0x28, 0x39 }, /* '(' => '9' */
        { 0x29, 0x30 }, /* ')' => '0' */
        { 0x2a, 0x38 }, /* '*' => '8' */
+       { 0x2b, 0x5e }, /* '+' => '^' */
        { 0x2d, 0x3d }, /* '-' => '=' */
        { 0x2f, 0x2d }, /* '/' => '-' */
        { 0x31, 0x2b }, /* '1' => '+' */
@@ -43,6 +44,7 @@ static struct keymap_key cz_basic[] = {
        { 0x7b, 0x2f }, /* '{' => '/' */
        { 0x7c, 0x27 }, /* '|' => '\'' */
        { 0x7d, 0x28 }, /* '}' => '(' */
+       { 0x7e, 0x60 }, /* '~' => '`' */
        { 0, 0 }
 };
 
@@ -55,16 +57,14 @@ static struct keymap_key cz_altgr[] = {
        { 0x32, 0x40 }, /* '2' => '@' */
        { 0x33, 0x23 }, /* '3' => '#' */
        { 0x34, 0x24 }, /* '4' => '$' */
-       { 0x36, 0x5e }, /* '6' => '^' */
        { 0x37, 0x26 }, /* '7' => '&' */
        { 0x38, 0x2a }, /* '8' => '*' */
        { 0x39, 0x7b }, /* '9' => '{' */
        { 0x3b, 0x24 }, /* ';' => '$' */
+       { 0x61, 0x7e }, /* 'a' => '~' */
        { 0x62, 0x7b }, /* 'b' => '{' */
        { 0x63, 0x26 }, /* 'c' => '&' */
        { 0x67, 0x5d }, /* 'g' => ']' */
-       { 0x68, 0x60 }, /* 'h' => '`' */
-       { 0x6d, 0x5e }, /* 'm' => '^' */
        { 0x6e, 0x7d }, /* 'n' => '}' */
        { 0x76, 0x40 }, /* 'v' => '@' */
        { 0x78, 0x23 }, /* 'x' => '#' */
index 4a889a2425b85f0a5852a27070b58bfce3b7bb75..bbd39520f057e9342f04553d9fd656924825397e 100644 (file)
@@ -21,6 +21,7 @@ static struct keymap_key de_basic[] = {
        { 0x28, 0x29 }, /* '(' => ')' */
        { 0x29, 0x3d }, /* ')' => '=' */
        { 0x2a, 0x28 }, /* '*' => '(' */
+       { 0x2b, 0x60 }, /* '+' => '`' */
        { 0x2f, 0x2d }, /* '/' => '-' */
        { 0x3c, 0x3b }, /* '<' => ';' */
        { 0x3e, 0x3a }, /* '>' => ':' */
@@ -32,6 +33,7 @@ static struct keymap_key de_basic[] = {
        { 0x5d, 0x2b }, /* ']' => '+' */
        { 0x5e, 0x26 }, /* '^' => '&' */
        { 0x5f, 0x3f }, /* '_' => '?' */
+       { 0x60, 0x5e }, /* '`' => '^' */
        { 0x79, 0x7a }, /* 'y' => 'z' */
        { 0x7a, 0x79 }, /* 'z' => 'y' */
        { 0x7c, 0x27 }, /* '|' => '\'' */
index 4d40743b17cc098cac4a713aadd5924c14cb5305..6d2e60aca94879a45ae9244a7f4d908de56e0d8d 100644 (file)
@@ -18,6 +18,7 @@ static struct keymap_key dk_basic[] = {
        { 0x28, 0x29 }, /* '(' => ')' */
        { 0x29, 0x3d }, /* ')' => '=' */
        { 0x2a, 0x28 }, /* '*' => '(' */
+       { 0x2b, 0x60 }, /* '+' => '`' */
        { 0x2d, 0x2b }, /* '-' => '+' */
        { 0x2f, 0x2d }, /* '/' => '-' */
        { 0x3c, 0x3b }, /* '<' => ';' */
@@ -28,6 +29,7 @@ static struct keymap_key dk_basic[] = {
        { 0x5e, 0x26 }, /* '^' => '&' */
        { 0x5f, 0x3f }, /* '_' => '?' */
        { 0x7c, 0x2a }, /* '|' => '*' */
+       { 0x7d, 0x5e }, /* '}' => '^' */
        { 0xdc, 0x3c }, /* Pseudo-'\\' => '<' */
        { 0xfc, 0x3e }, /* Pseudo-'|' => '>' */
        { 0, 0 }
@@ -35,6 +37,7 @@ static struct keymap_key dk_basic[] = {
 
 /** "dk" AltGr remapping */
 static struct keymap_key dk_altgr[] = {
+       { 0x30, 0x7d }, /* '0' => '}' */
        { 0x32, 0x40 }, /* '2' => '@' */
        { 0x3d, 0x7c }, /* '=' => '|' */
        { 0x71, 0x40 }, /* 'q' => '@' */
index 397e2cbaa1fd584019adbd98b922ee516d35d6c7..614ca7b8b4c6da66edd2406906f5772a866ee95a 100644 (file)
@@ -24,9 +24,11 @@ static struct keymap_key es_basic[] = {
        { 0x3e, 0x3a }, /* '>' => ':' */
        { 0x3f, 0x5f }, /* '?' => '_' */
        { 0x40, 0x22 }, /* '@' => '"' */
+       { 0x5b, 0x60 }, /* '[' => '`' */
        { 0x5d, 0x2b }, /* ']' => '+' */
        { 0x5e, 0x26 }, /* '^' => '&' */
        { 0x5f, 0x3f }, /* '_' => '?' */
+       { 0x7b, 0x5e }, /* '{' => '^' */
        { 0x7d, 0x2a }, /* '}' => '*' */
        { 0xdc, 0x3c }, /* Pseudo-'\\' => '<' */
        { 0xfc, 0x3e }, /* Pseudo-'|' => '>' */
@@ -35,8 +37,11 @@ static struct keymap_key es_basic[] = {
 
 /** "es" AltGr remapping */
 static struct keymap_key es_altgr[] = {
+       { 0x27, 0x7b }, /* '\'' => '{' */
        { 0x30, 0x7d }, /* '0' => '}' */
        { 0x32, 0x40 }, /* '2' => '@' */
+       { 0x37, 0x7b }, /* '7' => '{' */
+       { 0x38, 0x5b }, /* '8' => '[' */
        { 0x39, 0x5d }, /* '9' => ']' */
        { 0x5c, 0x7d }, /* '\\' => '}' */
        { 0x71, 0x40 }, /* 'q' => '@' */
index 4120dbed92c95481fdbcfdb4080eb0893abeb40c..f3eb02eabccb5209abe138f5751d95bcb750842b 100644 (file)
@@ -16,6 +16,7 @@ static struct keymap_key et_basic[] = {
        { 0x28, 0x29 }, /* '(' => ')' */
        { 0x29, 0x3d }, /* ')' => '=' */
        { 0x2a, 0x28 }, /* '*' => '(' */
+       { 0x2b, 0x60 }, /* '+' => '`' */
        { 0x2d, 0x2b }, /* '-' => '+' */
        { 0x2f, 0x2d }, /* '/' => '-' */
        { 0x3c, 0x3b }, /* '<' => ';' */
@@ -25,6 +26,7 @@ static struct keymap_key et_basic[] = {
        { 0x5c, 0x27 }, /* '\\' => '\'' */
        { 0x5e, 0x26 }, /* '^' => '&' */
        { 0x5f, 0x3f }, /* '_' => '?' */
+       { 0x60, 0x5e }, /* '`' => '^' */
        { 0x7c, 0x2a }, /* '|' => '*' */
        { 0xdc, 0x3c }, /* Pseudo-'\\' => '<' */
        { 0xfc, 0x3e }, /* Pseudo-'|' => '>' */
@@ -33,7 +35,6 @@ static struct keymap_key et_basic[] = {
 
 /** "et" AltGr remapping */
 static struct keymap_key et_altgr[] = {
-       { 0x27, 0x5e }, /* '\'' => '^' */
        { 0x2d, 0x5c }, /* '-' => '\\' */
        { 0x32, 0x40 }, /* '2' => '@' */
        { 0xdc, 0x7c }, /* Pseudo-'\\' => '|' */
index 978121a888252debeff82f74390f03abcb728243..622f06252f905229b83a0db55981e16c0a7ff0a8 100644 (file)
@@ -16,6 +16,7 @@ static struct keymap_key fi_basic[] = {
        { 0x28, 0x29 }, /* '(' => ')' */
        { 0x29, 0x3d }, /* ')' => '=' */
        { 0x2a, 0x28 }, /* '*' => '(' */
+       { 0x2b, 0x60 }, /* '+' => '`' */
        { 0x2d, 0x2b }, /* '-' => '+' */
        { 0x2f, 0x2d }, /* '/' => '-' */
        { 0x3c, 0x3b }, /* '<' => ';' */
@@ -26,6 +27,7 @@ static struct keymap_key fi_basic[] = {
        { 0x5e, 0x26 }, /* '^' => '&' */
        { 0x5f, 0x3f }, /* '_' => '?' */
        { 0x7c, 0x2a }, /* '|' => '*' */
+       { 0x7d, 0x5e }, /* '}' => '^' */
        { 0xdc, 0x3c }, /* Pseudo-'\\' => '<' */
        { 0xfc, 0x3e }, /* Pseudo-'|' => '>' */
        { 0, 0 }
@@ -34,6 +36,7 @@ static struct keymap_key fi_basic[] = {
 /** "fi" AltGr remapping */
 static struct keymap_key fi_altgr[] = {
        { 0x2d, 0x5c }, /* '-' => '\\' */
+       { 0x30, 0x7d }, /* '0' => '}' */
        { 0x32, 0x40 }, /* '2' => '@' */
        { 0xdc, 0x7c }, /* Pseudo-'\\' => '|' */
        { 0, 0 }
index c0a959f0d319581a5ed0a0383275b837a11ef042..c002bf95a57dcdc97c356ec6a6a919be7ed56540 100644 (file)
@@ -49,6 +49,7 @@ static struct keymap_key fr_basic[] = {
        { 0x51, 0x41 }, /* 'Q' => 'A' */
        { 0x57, 0x5a }, /* 'W' => 'Z' */
        { 0x5a, 0x57 }, /* 'Z' => 'W' */
+       { 0x5b, 0x5e }, /* '[' => '^' */
        { 0x5c, 0x2a }, /* '\\' => '*' */
        { 0x5d, 0x24 }, /* ']' => '$' */
        { 0x5e, 0x36 }, /* '^' => '6' */
@@ -67,8 +68,8 @@ static struct keymap_key fr_altgr[] = {
        { 0x2d, 0x5d }, /* '-' => ']' */
        { 0x30, 0x40 }, /* '0' => '@' */
        { 0x33, 0x23 }, /* '3' => '#' */
+       { 0x35, 0x5b }, /* '5' => '[' */
        { 0x38, 0x5c }, /* '8' => '\\' */
-       { 0x39, 0x5e }, /* '9' => '^' */
        { 0x61, 0x40 }, /* 'a' => '@' */
        { 0, 0 }
 };
index 64e27dda631188fbef0e7b9a0336d82e58c1be6c..8f2d70aac7d05e22077793d768fd06cd89401949 100644 (file)
@@ -39,6 +39,7 @@ static struct keymap_key hu_basic[] = {
 static struct keymap_key hu_altgr[] = {
        { 0x2e, 0x3e }, /* '.' => '>' */
        { 0x2f, 0x2a }, /* '/' => '*' */
+       { 0x32, 0x5e }, /* '2' => '^' */
        { 0x33, 0x5e }, /* '3' => '^' */
        { 0x37, 0x60 }, /* '7' => '`' */
        { 0x3b, 0x24 }, /* ';' => '$' */
index f67bbadcbdcb668c7598381feb19eddc44fc4a43..a55dafe6a0455abc50919483aa0ea044e4e8d924 100644 (file)
@@ -42,6 +42,7 @@ static struct keymap_key it_altgr[] = {
        { 0x39, 0x5d }, /* '9' => ']' */
        { 0x3b, 0x40 }, /* ';' => '@' */
        { 0x3d, 0x7e }, /* '=' => '~' */
+       { 0x5c, 0x60 }, /* '\\' => '`' */
        { 0x71, 0x40 }, /* 'q' => '@' */
        { 0, 0 }
 };
index bbee4cbdf0889ed5a06125b783f9091c38b6783e..8038d4d370bf137bc00a444acc5c820bfaec9b32 100644 (file)
@@ -15,10 +15,12 @@ static struct keymap_key nl_basic[] = {
        { 0x1c, 0x3c }, /* 0x1c => '<' */
        { 0x1d, 0x1c }, /* 0x1d => 0x1c */
        { 0x1e, 0x36 }, /* 0x1e => '6' */
+       { 0x22, 0x60 }, /* '"' => '`' */
        { 0x26, 0x5f }, /* '&' => '_' */
        { 0x28, 0x29 }, /* '(' => ')' */
        { 0x29, 0x27 }, /* ')' => '\'' */
        { 0x2a, 0x28 }, /* '*' => '(' */
+       { 0x2b, 0x7e }, /* '+' => '~' */
        { 0x2d, 0x2f }, /* '-' => '/' */
        { 0x2f, 0x2d }, /* '/' => '-' */
        { 0x3b, 0x2b }, /* ';' => '+' */
@@ -31,6 +33,7 @@ static struct keymap_key nl_basic[] = {
        { 0x5e, 0x26 }, /* '^' => '&' */
        { 0x5f, 0x3f }, /* '_' => '?' */
        { 0x60, 0x40 }, /* '`' => '@' */
+       { 0x7b, 0x5e }, /* '{' => '^' */
        { 0x7c, 0x3e }, /* '|' => '>' */
        { 0x7d, 0x7c }, /* '}' => '|' */
        { 0xdc, 0x5d }, /* Pseudo-'\\' => ']' */
@@ -41,6 +44,7 @@ static struct keymap_key nl_basic[] = {
 /** "nl" AltGr remapping */
 static struct keymap_key nl_altgr[] = {
        { 0x2d, 0x5c }, /* '-' => '\\' */
+       { 0x38, 0x7b }, /* '8' => '{' */
        { 0x39, 0x7d }, /* '9' => '}' */
        { 0, 0 }
 };
index 95a95428b95c6c3894f99071c223ba98fc7c3974..4b2f7268ebb1eda1d974d6d925f4f9b404931629 100644 (file)
@@ -18,6 +18,7 @@ static struct keymap_key no_basic[] = {
        { 0x28, 0x29 }, /* '(' => ')' */
        { 0x29, 0x3d }, /* ')' => '=' */
        { 0x2a, 0x28 }, /* '*' => '(' */
+       { 0x2b, 0x60 }, /* '+' => '`' */
        { 0x2d, 0x2b }, /* '-' => '+' */
        { 0x2f, 0x2d }, /* '/' => '-' */
        { 0x3c, 0x3b }, /* '<' => ';' */
@@ -30,6 +31,7 @@ static struct keymap_key no_basic[] = {
        { 0x5f, 0x3f }, /* '_' => '?' */
        { 0x60, 0x7c }, /* '`' => '|' */
        { 0x7c, 0x2a }, /* '|' => '*' */
+       { 0x7d, 0x5e }, /* '}' => '^' */
        { 0xdc, 0x3c }, /* Pseudo-'\\' => '<' */
        { 0xfc, 0x3e }, /* Pseudo-'|' => '>' */
        { 0, 0 }
@@ -37,6 +39,7 @@ static struct keymap_key no_basic[] = {
 
 /** "no" AltGr remapping */
 static struct keymap_key no_altgr[] = {
+       { 0x30, 0x7d }, /* '0' => '}' */
        { 0x32, 0x40 }, /* '2' => '@' */
        { 0x71, 0x40 }, /* 'q' => '@' */
        { 0, 0 }
index 99ba52e4b497506e5bbdc14952dbbe2a7eb760a3..f294e9563cd6094de8e44a58bb66f4e945e51725 100644 (file)
@@ -12,6 +12,7 @@ FILE_LICENCE ( PUBLIC_DOMAIN );
 
 /** "pt" basic remapping */
 static struct keymap_key pt_basic[] = {
+       { 0x1c, 0x7e }, /* 0x1c => '~' */
        { 0x1e, 0x36 }, /* 0x1e => '6' */
        { 0x26, 0x2f }, /* '&' => '/' */
        { 0x28, 0x29 }, /* '(' => ')' */
@@ -24,10 +25,13 @@ static struct keymap_key pt_basic[] = {
        { 0x3f, 0x5f }, /* '?' => '_' */
        { 0x40, 0x22 }, /* '@' => '"' */
        { 0x5b, 0x2b }, /* '[' => '+' */
+       { 0x5c, 0x7e }, /* '\\' => '~' */
        { 0x5e, 0x26 }, /* '^' => '&' */
        { 0x5f, 0x3f }, /* '_' => '?' */
        { 0x60, 0x5c }, /* '`' => '\\' */
        { 0x7b, 0x2a }, /* '{' => '*' */
+       { 0x7c, 0x5e }, /* '|' => '^' */
+       { 0x7d, 0x60 }, /* '}' => '`' */
        { 0x7e, 0x7c }, /* '~' => '|' */
        { 0xdc, 0x3c }, /* Pseudo-'\\' => '<' */
        { 0xfc, 0x3e }, /* Pseudo-'|' => '>' */
@@ -36,6 +40,7 @@ static struct keymap_key pt_basic[] = {
 
 /** "pt" AltGr remapping */
 static struct keymap_key pt_altgr[] = {
+       { 0x30, 0x7d }, /* '0' => '}' */
        { 0x32, 0x40 }, /* '2' => '@' */
        { 0x37, 0x7b }, /* '7' => '{' */
        { 0x38, 0x5b }, /* '8' => '[' */
index ff5ff0a87ad4d0fdb93fe2ab66292f8cf3ca5ddd..42ccee175aa31f771f97f146fce3363bdd54b305 100755 (executable)
@@ -54,6 +54,14 @@ class KeyType(IntEnum):
     UNKNOWN = 0xf0
 
 
+class DeadKey(IntEnum):
+    """Dead keys"""
+
+    GRAVE = 0
+    CIRCUMFLEX = 2
+    TILDE = 3
+
+
 class KeyModifiers(Flag):
     """Key modifiers"""
 
@@ -96,6 +104,13 @@ class Key:
                                            KeyType.LETTER}
     """Key types with direct ASCII values"""
 
+    DEAD_KEYS: ClassVar[Mapping[int, str]] = {
+        DeadKey.GRAVE: '`',
+        DeadKey.CIRCUMFLEX: '^',
+        DeadKey.TILDE: '~',
+    }
+    """Dead key replacement ASCII values"""
+
     @property
     def keytype(self) -> Optional[KeyType]:
         """Key type"""
@@ -112,11 +127,14 @@ class Key:
     @property
     def ascii(self) -> Optional[str]:
         """ASCII character"""
-        if self.keytype in self.ASCII_TYPES:
-            value = self.value
+        keytype = self.keytype
+        value = self.value
+        if keytype in self.ASCII_TYPES:
             char = chr(value)
             if value and char.isascii():
                 return char
+        if keytype == KeyType.DEAD:
+            return self.DEAD_KEYS.get(value)
         return None