summaryrefslogtreecommitdiff
path: root/src/keysym.c
diff options
context:
space:
mode:
authorRan Benita <ran234@gmail.com>2012-07-13 18:55:10 +0300
committerRan Benita <ran234@gmail.com>2012-07-13 19:11:15 +0300
commit57374c3237d5976231a57fdcd9270ddcae313efb (patch)
tree9ad4aa9ab16dea5214a38fa1046470c0c865175a /src/keysym.c
parent0765064b35be2e1a0390bb9ecc4f8bad2879dbfd (diff)
downloadxorg-lib-libxkbcommon-57374c3237d5976231a57fdcd9270ddcae313efb.tar.gz
Rename KSIsLower/Upper and move to keysym.c
Seems like a more natural place, and allows to remove the src/misc.c file. Signed-off-by: Ran Benita <ran234@gmail.com>
Diffstat (limited to 'src/keysym.c')
-rw-r--r--src/keysym.c119
1 files changed, 119 insertions, 0 deletions
diff --git a/src/keysym.c b/src/keysym.c
index 6004aad..d46f7dc 100644
--- a/src/keysym.c
+++ b/src/keysym.c
@@ -158,3 +158,122 @@ xkb_keysym_from_name(const char *s)
return XKB_KEY_NoSymbol;
}
+
+enum keysym_case {
+ NONE,
+ LOWERCASE,
+ UPPERCASE,
+};
+
+static enum keysym_case
+keysym_get_case(xkb_keysym_t ks)
+{
+ unsigned set = (ks & (~0xff)) >> 8;
+
+ switch (set) {
+ case 0: /* latin 1 */
+ if ((ks >= XKB_KEY_A && ks <= XKB_KEY_Z) ||
+ (ks >= XKB_KEY_Agrave && ks <= XKB_KEY_THORN && ks != XKB_KEY_multiply))
+ return UPPERCASE;
+ if ((ks >= XKB_KEY_a && ks <= XKB_KEY_z) ||
+ (ks >= XKB_KEY_agrave && ks <= XKB_KEY_ydiaeresis))
+ return LOWERCASE;
+ break;
+ case 1: /* latin 2 */
+ if ((ks >= XKB_KEY_Aogonek && ks <= XKB_KEY_Zabovedot && ks != XKB_KEY_breve) ||
+ (ks >= XKB_KEY_Racute && ks<=XKB_KEY_Tcedilla))
+ return UPPERCASE;
+ if ((ks >= XKB_KEY_aogonek && ks <= XKB_KEY_zabovedot && ks != XKB_KEY_caron) ||
+ (ks >= XKB_KEY_racute && ks <= XKB_KEY_tcedilla))
+ return LOWERCASE;
+ break;
+ case 2: /* latin 3 */
+ if ((ks >= XKB_KEY_Hstroke && ks <= XKB_KEY_Jcircumflex) ||
+ (ks >= XKB_KEY_Cabovedot && ks <= XKB_KEY_Scircumflex))
+ return UPPERCASE;
+ if ((ks >= XKB_KEY_hstroke && ks <= XKB_KEY_jcircumflex) ||
+ (ks >= XKB_KEY_cabovedot && ks <= XKB_KEY_scircumflex))
+ return LOWERCASE;
+ break;
+ case 3: /* latin 4 */
+ if ((ks >= XKB_KEY_Rcedilla && ks <= XKB_KEY_Tslash) ||
+ (ks == XKB_KEY_ENG) ||
+ (ks >= XKB_KEY_Amacron && ks <= XKB_KEY_Umacron))
+ return UPPERCASE;
+ if ((ks >= XKB_KEY_rcedilla && ks <= XKB_KEY_tslash) ||
+ (ks == XKB_KEY_eng) ||
+ (ks >= XKB_KEY_amacron && ks <= XKB_KEY_umacron))
+ return LOWERCASE;
+ break;
+ case 6: /* Cyrillic */
+ if ((ks >= XKB_KEY_Serbian_DJE && ks <= XKB_KEY_Serbian_DZE) ||
+ (ks >= XKB_KEY_Cyrillic_YU && ks <= XKB_KEY_Cyrillic_HARDSIGN))
+ return UPPERCASE;
+ if ((ks >= XKB_KEY_Serbian_dje && ks <= XKB_KEY_Serbian_dze) ||
+ (ks >= XKB_KEY_Cyrillic_yu && ks <= XKB_KEY_Cyrillic_hardsign))
+ return LOWERCASE;
+ break;
+ case 7: /* Greek */
+ if ((ks >= XKB_KEY_Greek_ALPHAaccent &&
+ ks <= XKB_KEY_Greek_OMEGAaccent) ||
+ (ks >= XKB_KEY_Greek_ALPHA && ks <= XKB_KEY_Greek_OMEGA))
+ return UPPERCASE;
+ if ((ks >= XKB_KEY_Greek_alphaaccent &&
+ ks <= XKB_KEY_Greek_omegaaccent) ||
+ (ks >= XKB_KEY_Greek_alpha && ks <= XKB_KEY_Greek_OMEGA))
+ return LOWERCASE;
+ break;
+ case 18: /* latin 8 */
+ if ((ks == XKB_KEY_Wcircumflex) ||
+ (ks == XKB_KEY_Ycircumflex) ||
+ (ks == XKB_KEY_Babovedot) ||
+ (ks == XKB_KEY_Dabovedot) ||
+ (ks == XKB_KEY_Fabovedot) ||
+ (ks == XKB_KEY_Mabovedot) ||
+ (ks == XKB_KEY_Pabovedot) ||
+ (ks == XKB_KEY_Sabovedot) ||
+ (ks == XKB_KEY_Tabovedot) ||
+ (ks == XKB_KEY_Wdiaeresis) ||
+ (ks == XKB_KEY_Ygrave))
+ return UPPERCASE;
+ if ((ks == XKB_KEY_wcircumflex) ||
+ (ks == XKB_KEY_ycircumflex) ||
+ (ks == XKB_KEY_babovedot) ||
+ (ks == XKB_KEY_dabovedot) ||
+ (ks == XKB_KEY_fabovedot) ||
+ (ks == XKB_KEY_mabovedot) ||
+ (ks == XKB_KEY_pabovedot) ||
+ (ks == XKB_KEY_sabovedot) ||
+ (ks == XKB_KEY_tabovedot) ||
+ (ks == XKB_KEY_wdiaeresis) ||
+ (ks == XKB_KEY_ygrave))
+ return LOWERCASE;
+ break;
+ case 19: /* latin 9 */
+ if (ks == XKB_KEY_OE || ks == XKB_KEY_Ydiaeresis)
+ return UPPERCASE;
+ if (ks == XKB_KEY_oe)
+ return LOWERCASE;
+ break;
+ }
+
+ return NONE;
+}
+
+bool
+xkb_keysym_is_lower(xkb_keysym_t keysym)
+{
+ return keysym_get_case(keysym) == LOWERCASE;
+}
+
+bool
+xkb_keysym_is_upper(xkb_keysym_t keysym)
+{
+ return keysym_get_case(keysym) == UPPERCASE;
+}
+
+bool
+xkb_keysym_is_keypad(xkb_keysym_t keysym)
+{
+ return keysym >= XKB_KEY_KP_Space && keysym <= XKB_KEY_KP_Equal;
+}