KeysymStr.c revision b4ee4795
1
2/*
3
4Copyright 1990, 1998  The Open Group
5
6Permission to use, copy, modify, distribute, and sell this software and its
7documentation for any purpose is hereby granted without fee, provided that
8the above copyright notice appear in all copies and that both that
9copyright notice and this permission notice appear in supporting
10documentation.
11
12The above copyright notice and this permission notice shall be included in
13all copies or substantial portions of the Software.
14
15THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
18OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
19AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
20CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
21
22Except as contained in this notice, the name of The Open Group shall not be
23used in advertising or otherwise to promote the sale, use or other dealings
24in this Software without prior written authorization from The Open Group.
25
26*/
27
28#ifdef HAVE_CONFIG_H
29#include <config.h>
30#endif
31#include "Xlibint.h"
32#include <X11/Xresource.h>
33#include <X11/keysymdef.h>
34
35#include <stdio.h> /* sprintf */
36
37typedef unsigned long Signature;
38
39#define NEEDVTABLE
40#include "ks_tables.h"
41#include "Key.h"
42
43
44typedef struct _GRNData {
45    char *name;
46    XrmRepresentation type;
47    XrmValuePtr value;
48} GRNData;
49
50/*ARGSUSED*/
51static Bool
52SameValue(
53    XrmDatabase*	db,
54    XrmBindingList      bindings,
55    XrmQuarkList	quarks,
56    XrmRepresentation*  type,
57    XrmValuePtr		value,
58    XPointer		data
59)
60{
61    GRNData *gd = (GRNData *)data;
62
63    if ((*type == gd->type) && (value->size == gd->value->size) &&
64	!strncmp((char *)value->addr, (char *)gd->value->addr, value->size))
65    {
66	gd->name = XrmQuarkToString(*quarks); /* XXX */
67	return True;
68    }
69    return False;
70}
71
72char *XKeysymToString(KeySym ks)
73{
74    register int i, n;
75    int h;
76    register int idx;
77    const unsigned char *entry;
78    unsigned char val1, val2, val3, val4;
79    XrmDatabase keysymdb;
80
81    if (!ks || (ks & ((unsigned long) ~0x1fffffff)) != 0)
82	return ((char *)NULL);
83    if (ks == XK_VoidSymbol)
84	ks = 0;
85    if (ks <= 0x1fffffff)
86    {
87	val1 = ks >> 24;
88	val2 = (ks >> 16) & 0xff;
89	val3 = (ks >> 8) & 0xff;
90	val4 = ks & 0xff;
91	i = ks % VTABLESIZE;
92	h = i + 1;
93	n = VMAXHASH;
94	while ((idx = hashKeysym[i]))
95	{
96	    entry = &_XkeyTable[idx];
97	    if ((entry[0] == val1) && (entry[1] == val2) &&
98                (entry[2] == val3) && (entry[3] == val4))
99		return ((char *)entry + 4);
100	    if (!--n)
101		break;
102	    i += h;
103	    if (i >= VTABLESIZE)
104		i -= VTABLESIZE;
105	}
106    }
107
108    if ((keysymdb = _XInitKeysymDB()))
109    {
110	char buf[9];
111	XrmValue resval;
112	XrmQuark empty = NULLQUARK;
113	GRNData data;
114
115	sprintf(buf, "%lX", ks);
116	resval.addr = (XPointer)buf;
117	resval.size = strlen(buf) + 1;
118	data.name = (char *)NULL;
119	data.type = XrmPermStringToQuark("String");
120	data.value = &resval;
121	(void)XrmEnumerateDatabase(keysymdb, &empty, &empty, XrmEnumAllLevels,
122				   SameValue, (XPointer)&data);
123        if (data.name)
124	    return data.name;
125    }
126    if (ks >= 0x01000100 && ks <= 0x0110ffff) {
127        KeySym val = ks & 0xffffff;
128        char *s;
129        int i;
130        if (val & 0xff0000)
131            i = 10;
132        else
133            i = 6;
134        s = Xmalloc(i);
135        if (s == NULL)
136            return s;
137        i--;
138        s[i--] = '\0';
139        for (; i; i--){
140            val1 = val & 0xf;
141            val >>= 4;
142            if (val1 < 10)
143                s[i] = '0'+ val1;
144            else
145                s[i] = 'A'+ val1 - 10;
146        }
147        s[i] = 'U';
148        return s;
149    }
150    return ((char *) NULL);
151}
152