cleaner AltGr handling

This commit is contained in:
Vladimir 'phcoder' Serbinenko 2010-05-10 21:23:40 +02:00
parent 1ff38af9b9
commit 176194068f
2 changed files with 23 additions and 9 deletions

View file

@ -111,8 +111,13 @@ get_abstract_code (grub_term_input_t term, int in)
} }
static int static int
map (grub_term_input_t term __attribute__ ((unused)), int in) map (grub_term_input_t term, int in)
{ {
/* No match with AltGr. Interpret it as Alt rather than as L3 modifier then.
*/
if (in & GRUB_TERM_ALT_GR)
return map (term, in & ~GRUB_TERM_ALT_GR) | GRUB_TERM_ALT_GR;
if (in == GRUB_TERM_KEY_102) if (in == GRUB_TERM_KEY_102)
return '\\'; return '\\';
if (in == GRUB_TERM_KEY_SHIFT_102) if (in == GRUB_TERM_KEY_SHIFT_102)
@ -124,7 +129,7 @@ map (grub_term_input_t term __attribute__ ((unused)), int in)
static int static int
translate (grub_term_input_t term, int in) translate (grub_term_input_t term, int in)
{ {
int code, code2; int code, flags;
code = get_abstract_code (term, in); code = get_abstract_code (term, in);
if ((code & GRUB_TERM_CAPS) && (code & 0xff) >= 'a' && (code & 0xff) <= 'z') if ((code & GRUB_TERM_CAPS) && (code & 0xff) >= 'a' && (code & 0xff) <= 'z')
code = (code & 0xff) + 'A' - 'a'; code = (code & 0xff) + 'A' - 'a';
@ -132,13 +137,21 @@ translate (grub_term_input_t term, int in)
&& (code & 0xff) <= 'Z') && (code & 0xff) <= 'Z')
code = (code & 0xff) + 'a' - 'A'; code = (code & 0xff) + 'a' - 'A';
code2 = map (term, code & 0x1ffffff); flags = code & ~(GRUB_TERM_KEY_MASK | GRUB_TERM_ALT_GR);
if ((code & GRUB_TERM_CAPS) && (code2 & 0xff) >= 'a' && (code2 & 0xff) <= 'z') code &= (GRUB_TERM_KEY_MASK | GRUB_TERM_ALT_GR);
code2 = code2 + 'A' - 'a'; code = map (term, code);
else if ((code & GRUB_TERM_CAPS) && (code2 & 0xff) >= 'A' /* Transform unconsumed AltGr into Alt. */
&& (code2 & 0xff) <= 'Z') if (code & GRUB_TERM_ALT_GR)
code2 = code2 + 'a' - 'A'; {
return code2 | (code & ~0x1ffffff); flags |= GRUB_TERM_ALT;
code &= ~GRUB_TERM_ALT_GR;
}
if ((flags & GRUB_TERM_CAPS) && code >= 'a' && code <= 'z')
code += 'A' - 'a';
else if ((flags & GRUB_TERM_CAPS) && code >= 'A'
&& code <= 'Z')
code += 'a' - 'A';
return code | flags;
} }
static int static int

View file

@ -28,6 +28,7 @@
/* Keys without associated character. */ /* Keys without associated character. */
#define GRUB_TERM_EXTENDED 0x1000000 #define GRUB_TERM_EXTENDED 0x1000000
#define GRUB_TERM_KEY_MASK 0x1ffffff
#define GRUB_TERM_KEY_LEFT (GRUB_TERM_EXTENDED | 1) #define GRUB_TERM_KEY_LEFT (GRUB_TERM_EXTENDED | 1)
#define GRUB_TERM_KEY_RIGHT (GRUB_TERM_EXTENDED | 2) #define GRUB_TERM_KEY_RIGHT (GRUB_TERM_EXTENDED | 2)
#define GRUB_TERM_KEY_UP (GRUB_TERM_EXTENDED | 3) #define GRUB_TERM_KEY_UP (GRUB_TERM_EXTENDED | 3)