1 /************************************************************
2 Copyright (c) 1993 by Silicon Graphics Computer Systems, Inc.
4 Permission to use, copy, modify, and distribute this
5 software and its documentation for any purpose and without
6 fee is hereby granted, provided that the above copyright
7 notice appear in all copies and that both that copyright
8 notice and this permission notice appear in supporting
9 documentation, and that the name of Silicon Graphics not be
10 used in advertising or publicity pertaining to distribution
11 of the software without specific prior written permission.
12 Silicon Graphics makes no representation about the suitability
13 of this software for any purpose. It is provided "as is"
14 without any express or implied warranty.
16 SILICON GRAPHICS DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS
17 SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
18 AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL SILICON
19 GRAPHICS BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL
20 DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
21 DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
22 OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH
23 THE USE OR PERFORMANCE OF THIS SOFTWARE.
25 ********************************************************/
30 #define mapSize(m) (sizeof(m) / sizeof(struct xkb_kt_map_entry))
31 static struct xkb_kt_map_entry map2Level[]= {
32 { true, ShiftMask, {1, ShiftMask, 0} }
35 static struct xkb_kt_map_entry mapAlpha[]= {
36 { true, ShiftMask, { 1, ShiftMask, 0 } },
37 { true, LockMask, { 0, LockMask, 0 } }
40 static struct xkb_mods preAlpha[]= {
42 { LockMask, LockMask, 0 }
45 #define NL_VMOD_MASK 0
46 static struct xkb_kt_map_entry mapKeypad[]= {
47 { true, ShiftMask, { 1, ShiftMask, 0 } },
48 { false, 0, { 1, 0, NL_VMOD_MASK } }
51 static struct xkb_key_type canonicalTypes[XkbNumRequiredTypes] = {
58 { { ShiftMask, ShiftMask, 0 },
60 mapSize(map2Level), /* map_count */
64 { { ShiftMask|LockMask, ShiftMask|LockMask, 0 },
66 mapSize(mapAlpha), /* map_count */
70 { { ShiftMask, ShiftMask, NL_VMOD_MASK },
72 mapSize(mapKeypad), /* map_count */
79 XkbcInitCanonicalKeyTypes(struct xkb_keymap *keymap, unsigned which,
82 struct xkb_client_map * map;
83 struct xkb_key_type *from, *to;
89 rtrn = XkbcAllocClientMap(keymap, XkbKeyTypesMask, XkbNumRequiredTypes);
94 if ((which & XkbAllRequiredTypes) == 0)
98 from = canonicalTypes;
101 if (which & XkbOneLevelMask)
102 rtrn = XkbcCopyKeyType(&from[XkbOneLevelIndex], &to[XkbOneLevelIndex]);
104 if ((which & XkbTwoLevelMask) && (rtrn == Success))
105 rtrn = XkbcCopyKeyType(&from[XkbTwoLevelIndex], &to[XkbTwoLevelIndex]);
107 if ((which & XkbAlphabeticMask) && (rtrn == Success))
108 rtrn = XkbcCopyKeyType(&from[XkbAlphabeticIndex],
109 &to[XkbAlphabeticIndex]);
111 if ((which & XkbKeypadMask) && (rtrn == Success)) {
112 struct xkb_key_type * type;
114 rtrn = XkbcCopyKeyType(&from[XkbKeypadIndex], &to[XkbKeypadIndex]);
115 type = &to[XkbKeypadIndex];
117 if ((keypadVMod >= 0) && (keypadVMod < XkbNumVirtualMods) &&
119 type->mods.vmods = (1 << keypadVMod);
120 type->map[0].active = true;
121 type->map[0].mods.mask = ShiftMask;
122 type->map[0].mods.real_mods = ShiftMask;
123 type->map[0].mods.vmods = 0;
124 type->map[0].level = 1;
125 type->map[1].active = false;
126 type->map[1].mods.mask = 0;
127 type->map[1].mods.real_mods = 0;
128 type->map[1].mods.vmods = (1 << keypadVMod);
129 type->map[1].level = 1;
137 _XkbcKSCheckCase(xkb_keysym_t ks)
139 unsigned set = (ks & (~0xff)) >> 8;
143 case 0: /* latin 1 */
144 if ((ks >= XKB_KEY_A && ks <= XKB_KEY_Z) ||
145 (ks >= XKB_KEY_Agrave && ks <= XKB_KEY_THORN && ks != XKB_KEY_multiply))
147 if ((ks >= XKB_KEY_a && ks <= XKB_KEY_z) ||
148 (ks >= XKB_KEY_agrave && ks <= XKB_KEY_ydiaeresis))
151 case 1: /* latin 2 */
152 if ((ks >= XKB_KEY_Aogonek && ks <= XKB_KEY_Zabovedot && ks != XKB_KEY_breve) ||
153 (ks >= XKB_KEY_Racute && ks<=XKB_KEY_Tcedilla))
155 if ((ks >= XKB_KEY_aogonek && ks <= XKB_KEY_zabovedot && ks != XKB_KEY_caron) ||
156 (ks >= XKB_KEY_racute && ks <= XKB_KEY_tcedilla))
159 case 2: /* latin 3 */
160 if ((ks >= XKB_KEY_Hstroke && ks <= XKB_KEY_Jcircumflex) ||
161 (ks >= XKB_KEY_Cabovedot && ks <= XKB_KEY_Scircumflex))
163 if ((ks >= XKB_KEY_hstroke && ks <= XKB_KEY_jcircumflex) ||
164 (ks >= XKB_KEY_cabovedot && ks <= XKB_KEY_scircumflex))
167 case 3: /* latin 4 */
168 if ((ks >= XKB_KEY_Rcedilla && ks <= XKB_KEY_Tslash) ||
169 (ks == XKB_KEY_ENG) ||
170 (ks >= XKB_KEY_Amacron && ks <= XKB_KEY_Umacron))
172 if ((ks >= XKB_KEY_rcedilla && ks <= XKB_KEY_tslash) ||
173 (ks == XKB_KEY_eng) ||
174 (ks >= XKB_KEY_amacron && ks <= XKB_KEY_umacron))
177 case 18: /* latin 8 */
178 if ((ks == XKB_KEY_Wcircumflex) ||
179 (ks == XKB_KEY_Ycircumflex) ||
180 (ks == XKB_KEY_Babovedot) ||
181 (ks == XKB_KEY_Dabovedot) ||
182 (ks == XKB_KEY_Fabovedot) ||
183 (ks == XKB_KEY_Mabovedot) ||
184 (ks == XKB_KEY_Pabovedot) ||
185 (ks == XKB_KEY_Sabovedot) ||
186 (ks == XKB_KEY_Tabovedot) ||
187 (ks == XKB_KEY_Wdiaeresis) ||
188 (ks == XKB_KEY_Ygrave))
190 if ((ks == XKB_KEY_wcircumflex) ||
191 (ks == XKB_KEY_ycircumflex) ||
192 (ks == XKB_KEY_babovedot) ||
193 (ks == XKB_KEY_dabovedot) ||
194 (ks == XKB_KEY_fabovedot) ||
195 (ks == XKB_KEY_mabovedot) ||
196 (ks == XKB_KEY_pabovedot) ||
197 (ks == XKB_KEY_sabovedot) ||
198 (ks == XKB_KEY_tabovedot) ||
199 (ks == XKB_KEY_wdiaeresis) ||
200 (ks == XKB_KEY_ygrave))
203 case 19: /* latin 9 */
204 if (ks == XKB_KEY_OE || ks == XKB_KEY_Ydiaeresis)
206 if (ks == XKB_KEY_oe)