1 /************************************************************
2 Copyright (c) 1994 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 ********************************************************/
29 #define BUFFER_SIZE 1024
30 static char textBuffer[BUFFER_SIZE];
31 static unsigned int tbNext = 0;
34 tbGetBuffer(unsigned int size)
38 if (size >= BUFFER_SIZE)
41 if ((BUFFER_SIZE - tbNext) <= size)
44 rtrn = &textBuffer[tbNext];
51 XkbcVModIndexText(struct xkb_keymap * xkb, unsigned ndx)
55 const char *tmp = NULL;
58 if (ndx >= XkbNumVirtualMods)
60 else if (xkb && xkb->names)
61 tmp = xkb->names->vmods[ndx];
64 snprintf(buf, sizeof(buf) - 1, "%d", ndx);
68 len = strlen(tmp) + 1;
69 if (len >= BUFFER_SIZE)
70 len = BUFFER_SIZE - 1;
72 rtrn = tbGetBuffer(len);
73 strncpy(rtrn, tmp, len);
79 XkbcVModMaskText(struct xkb_keymap * xkb, unsigned modMask, unsigned mask)
82 const char *mm = NULL;
84 char buf[BUFFER_SIZE];
86 if ((modMask == 0) && (mask == 0))
90 mm = XkbcModMaskText(modMask, false);
97 for (i = 0, bit = 1; i < XkbNumVirtualMods && rem > 1; i++, bit <<= 1)
102 len = snprintf(str, rem, "%s%s",
103 (str != buf) ? "+" : "",
104 XkbcVModIndexText(xkb, i));
114 len = ((str) ? strlen(str) : 0) + ((mm) ? strlen(mm) : 0) +
115 ((str && mm) ? 1 : 0);
116 if (len >= BUFFER_SIZE)
117 len = BUFFER_SIZE - 1;
119 rtrn = tbGetBuffer(len + 1);
122 snprintf(rtrn, len + 1, "%s%s%s", (mm) ? mm : "",
123 (mm && str) ? "+" : "", (str) ? str : "");
128 static const char *modNames[XkbNumModifiers] = {
140 XkbcModIndexText(unsigned ndx)
144 if (ndx < XkbNumModifiers)
145 return modNames[ndx];
146 else if (ndx == XkbNoModifier)
149 buf = tbGetBuffer(32);
150 snprintf(buf, 32, "ILLEGAL_%02x", ndx);
156 XkbcModMaskText(unsigned mask, bool cFormat)
161 if ((mask & 0xff) == 0xff)
162 return (cFormat ? "0xff" : "all");
164 if ((mask & 0xff) == 0)
165 return (cFormat ? "0" : "none");
168 buf = tbGetBuffer(rem);
171 for (i = 0, bit = 1; i < XkbNumModifiers && rem > 1; i++, bit <<= 1) {
177 len = snprintf(str, rem, "%s%s%s",
178 (str != buf) ? (cFormat ? "|" : "+") : "",
180 cFormat ? "Mask" : "");
189 XkbcConfigText(unsigned config)
192 case XkmSemanticsFile:
200 case XkmCompatMapIndex:
202 case XkmSymbolsIndex:
204 case XkmKeyNamesIndex:
211 static const char *actionTypeNames[XkbSA_NumActions]= {
212 "NoAction", /* XkbSA_NoAction */
213 "SetMods", /* XkbSA_SetMods */
214 "LatchMods", /* XkbSA_LatchMods */
215 "LockMods", /* XkbSA_LockMods */
216 "SetGroup", /* XkbSA_SetGroup */
217 "LatchGroup", /* XkbSA_LatchGroup */
218 "LockGroup", /* XkbSA_LockGroup */
219 "MovePtr", /* XkbSA_MovePtr */
220 "PtrBtn", /* XkbSA_PtrBtn */
221 "LockPtrBtn", /* XkbSA_LockPtrBtn */
222 "SetPtrDflt", /* XkbSA_SetPtrDflt */
223 "ISOLock", /* XkbSA_ISOLock */
224 "Terminate", /* XkbSA_Terminate */
225 "SwitchScreen", /* XkbSA_SwitchScreen */
226 "SetControls", /* XkbSA_SetControls */
227 "LockControls", /* XkbSA_LockControls */
228 "ActionMessage", /* XkbSA_ActionMessage */
229 "RedirectKey", /* XkbSA_RedirectKey */
230 "DeviceBtn", /* XkbSA_DeviceBtn */
231 "LockDeviceBtn", /* XkbSA_LockDeviceBtn */
232 "DeviceValuator" /* XkbSA_DeviceValuator */
236 XkbcActionTypeText(unsigned type)
238 if (type <= XkbSA_LastAction)
239 return actionTypeNames[type];
244 XkbcKeysymText(xkb_keysym_t sym)
246 static char buffer[16];
248 xkb_keysym_get_name(sym, buffer, sizeof buffer);
254 XkbcKeyNameText(char *name)
259 buf = tbGetBuffer(7);
261 strncpy(&buf[1], name, 4);
270 static const char *siMatchText[5] = {
271 "NoneOf", /* XkbSI_NoneOf */
272 "AnyOfOrNone", /* XkbSI_AnyOfOrNone */
273 "AnyOf", /* XkbSI_AnyOf */
274 "AllOf", /* XkbSI_AllOf */
275 "Exactly" /* XkbSI_Exactly */
279 XkbcSIMatchText(unsigned type)
283 switch (type & XkbSI_OpMask) {
285 return siMatchText[0];
286 case XkbSI_AnyOfOrNone:
287 return siMatchText[1];
289 return siMatchText[2];
291 return siMatchText[3];
293 return siMatchText[4];
295 buf = tbGetBuffer(40);
296 snprintf(buf, 40, "0x%x", type & XkbSI_OpMask);