cleaner AltGr handling
This commit is contained in:
parent
1ff38af9b9
commit
176194068f
2 changed files with 23 additions and 9 deletions
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in a new issue