diff options
Diffstat (limited to 'sys/dev/wscons/wskbd.c')
-rw-r--r-- | sys/dev/wscons/wskbd.c | 81 |
1 files changed, 31 insertions, 50 deletions
diff --git a/sys/dev/wscons/wskbd.c b/sys/dev/wscons/wskbd.c index 5532b9d9faa..e21ad8f8cd1 100644 --- a/sys/dev/wscons/wskbd.c +++ b/sys/dev/wscons/wskbd.c @@ -1,4 +1,4 @@ -/* $OpenBSD: wskbd.c,v 1.16 2001/05/08 22:28:43 mickey Exp $ */ +/* $OpenBSD: wskbd.c,v 1.17 2001/06/08 03:20:31 mickey Exp $ */ /* $NetBSD: wskbd.c,v 1.38 2000/03/23 07:01:47 thorpej Exp $ */ /* @@ -1488,43 +1488,43 @@ wskbd_translate(id, type, value) switch (kp->group1[0]) { case KS_Shift_L: update_modifier(id, type, 0, MOD_SHIFT_L); - goto kbrep; + break; case KS_Shift_R: update_modifier(id, type, 0, MOD_SHIFT_R); - goto kbrep; + break; case KS_Shift_Lock: update_modifier(id, type, 1, MOD_SHIFTLOCK); - goto kbrep; + break; case KS_Caps_Lock: update_modifier(id, type, 1, MOD_CAPSLOCK); - goto kbrep; + break; case KS_Control_L: update_modifier(id, type, 0, MOD_CONTROL_L); - goto kbrep; + break; case KS_Control_R: update_modifier(id, type, 0, MOD_CONTROL_R); - goto kbrep; + break; case KS_Alt_L: update_modifier(id, type, 0, MOD_META_L); - goto kbrep; + break; case KS_Alt_R: update_modifier(id, type, 0, MOD_META_R); - goto kbrep; + break; case KS_Mode_switch: update_modifier(id, type, 0, MOD_MODESHIFT); - goto kbrep; + break; case KS_Num_Lock: update_modifier(id, type, 1, MOD_NUMLOCK); - goto kbrep; + break; #if NWSDISPLAY > 0 case KS_Hold_Screen: @@ -1532,26 +1532,24 @@ wskbd_translate(id, type, value) update_modifier(id, type, 1, MOD_HOLDSCREEN); wskbd_holdscreen(sc, id->t_modifiers & MOD_HOLDSCREEN); } - goto kbrep; + break; + + default: + if (sc != NULL && sc->sc_repeating && + ((type == WSCONS_EVENT_KEY_UP && value != sc->sc_repkey) || + (type == WSCONS_EVENT_KEY_DOWN && value == sc->sc_repkey))) + return (0); #endif } #if NWSDISPLAY > 0 - if (sc != NULL && sc->sc_repeating) { - if ((type == WSCONS_EVENT_KEY_UP && value != sc->sc_repkey) || - (type == WSCONS_EVENT_KEY_DOWN && value == sc->sc_repkey)) - return (0); - } - -kbrep: - if (sc != NULL && sc->sc_repeating) { - sc->sc_repeating = 0; - timeout_del(&sc->sc_repeat_ch); - } - if (sc != NULL) + if (sc != NULL) { + if (sc->sc_repeating) { + sc->sc_repeating = 0; + timeout_del(&sc->sc_repeat_ch); + } sc->sc_repkey = value; -#else -kbrep: + } #endif /* If this is a key release or we are in command mode, we are done */ @@ -1566,29 +1564,12 @@ kbrep: else group = & kp->group1[0]; - if ((id->t_modifiers & MOD_NUMLOCK) != 0 && - KS_GROUP(group[1]) == KS_GROUP_Keypad) { - if (MOD_ONESET(id, MOD_ANYSHIFT)) - ksym = group[0]; - else - ksym = group[1]; - } else if (! MOD_ONESET(id, MOD_ANYSHIFT | MOD_CAPSLOCK)) { - ksym = group[0]; - } else if (MOD_ONESET(id, MOD_CAPSLOCK)) { - if (! MOD_ONESET(id, MOD_SHIFT_L | MOD_SHIFT_R)) - ksym = group[0]; - else - ksym = group[1]; - if (ksym >= KS_a && ksym <= KS_z) - ksym += KS_A - KS_a; - else if (ksym >= KS_agrave && ksym <= KS_thorn && - ksym != KS_division) - ksym += KS_Agrave - KS_agrave; - } else if (MOD_ONESET(id, MOD_ANYSHIFT)) { - ksym = group[1]; - } else { - ksym = group[0]; - } + if ((id->t_modifiers & MOD_NUMLOCK) && + KS_GROUP(group[1]) == KS_GROUP_Keypad) + ksym = group[!MOD_ONESET(id, MOD_ANYSHIFT)]; + else + ksym = group[MOD_ONESET(id, MOD_CAPSLOCK) ^ + MOD_ONESET(id, MOD_ANYSHIFT)]; /* Process compose sequence and dead accents */ res = KS_voidSymbol; @@ -1653,7 +1634,7 @@ kbrep: return (2); } else res |= 0x80; - } + } } id->t_symbols[0] = res; |