Lookup.c revision 6c321187
16c321187Smrg/* $Xorg: Lookup.c,v 1.4 2001/02/09 02:03:53 xorgcvs Exp $ */
26c321187Smrg
36c321187Smrg/*
46c321187Smrg
56c321187SmrgCopyright 1988, 1989, 1998  The Open Group
66c321187Smrg
76c321187SmrgPermission to use, copy, modify, distribute, and sell this software and its
86c321187Smrgdocumentation for any purpose is hereby granted without fee, provided that
96c321187Smrgthe above copyright notice appear in all copies and that both that
106c321187Smrgcopyright notice and this permission notice appear in supporting
116c321187Smrgdocumentation.
126c321187Smrg
136c321187SmrgThe above copyright notice and this permission notice shall be included in
146c321187Smrgall copies or substantial portions of the Software.
156c321187Smrg
166c321187SmrgTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
176c321187SmrgIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
186c321187SmrgFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
196c321187SmrgOPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
206c321187SmrgAN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
216c321187SmrgCONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
226c321187Smrg
236c321187SmrgExcept as contained in this notice, the name of The Open Group shall not be
246c321187Smrgused in advertising or otherwise to promote the sale, use or other dealings
256c321187Smrgin this Software without prior written authorization from The Open Group.
266c321187Smrg
276c321187Smrg*/
286c321187Smrg/* $XFree86: xc/lib/Xmu/Lookup.c,v 3.7 2001/01/17 19:42:56 dawes Exp $ */
296c321187Smrg
306c321187Smrg#ifdef HAVE_CONFIG_H
316c321187Smrg#include <config.h>
326c321187Smrg#endif
336c321187Smrg#include <X11/Xmu/Lookup.h>
346c321187Smrg
356c321187Smrg#define XK_LATIN1
366c321187Smrg#define XK_PUBLISHING
376c321187Smrg#include <X11/keysymdef.h>
386c321187Smrg
396c321187Smrg/* bit (1<<i) means character is in codeset i */
406c321187Smrgstatic unsigned short _Xconst latin1[128] =
416c321187Smrg  {0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
426c321187Smrg   0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
436c321187Smrg   0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
446c321187Smrg   0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
456c321187Smrg   0x10ee, 0x0000, 0x1000, 0x1084, 0x102e, 0x1000, 0x1080, 0x108e, /* 10 */
466c321187Smrg   0x108e, 0x1080, 0x0000, 0x1080, 0x1080, 0x10ee, 0x1000, 0x1008,
476c321187Smrg   0x108e, 0x1080, 0x1084, 0x1084, 0x108e, 0x1004, 0x1000, 0x1084, /* 11 */
486c321187Smrg   0x100e, 0x1000, 0x0000, 0x1080, 0x1000, 0x1084, 0x1000, 0x0000,
496c321187Smrg   0x0004, 0x000e, 0x000e, 0x0008, 0x000e, 0x0008, 0x0008, 0x0006, /* 12 */
506c321187Smrg   0x0004, 0x000e, 0x0004, 0x000e, 0x0004, 0x000e, 0x000e, 0x0004,
516c321187Smrg   0x0000, 0x0004, 0x0004, 0x0006, 0x000e, 0x0008, 0x000e, 0x000e, /* 13 */
526c321187Smrg   0x0008, 0x0004, 0x000e, 0x000c, 0x000e, 0x0002, 0x0000, 0x000e,
536c321187Smrg   0x0004, 0x000e, 0x000e, 0x0008, 0x000e, 0x0008, 0x0008, 0x0006, /* 14 */
546c321187Smrg   0x0004, 0x000e, 0x0004, 0x000e, 0x0004, 0x000e, 0x000e, 0x0004,
556c321187Smrg   0x0000, 0x0004, 0x0004, 0x0006, 0x000e, 0x0008, 0x000e, 0x000e, /* 15 */
566c321187Smrg   0x0008, 0x0004, 0x000e, 0x000c, 0x000e, 0x0002, 0x0000, 0x0000};
576c321187Smrg
586c321187Smrg/* bit (1<<i) means character is in codeset i */
596c321187Smrgstatic unsigned short _Xconst latin2[128] =
606c321187Smrg  {0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
616c321187Smrg   0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
626c321187Smrg   0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
636c321187Smrg   0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
646c321187Smrg   0x0000, 0x0008, 0x0004, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, /* 10 */
656c321187Smrg   0x0000, 0x0008, 0x0004, 0x0000, 0x0000, 0x0000, 0x0008, 0x0004,
666c321187Smrg   0x0000, 0x0008, 0x0008, 0x0000, 0x0000, 0x0000, 0x0000, 0x0008, /* 11 */
676c321187Smrg   0x0000, 0x0008, 0x0004, 0x0000, 0x0000, 0x0000, 0x0008, 0x0004,
686c321187Smrg   0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, /* 12 */
696c321187Smrg   0x0008, 0x0000, 0x0008, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
706c321187Smrg   0x0008, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, /* 13 */
716c321187Smrg   0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
726c321187Smrg   0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, /* 14 */
736c321187Smrg   0x0008, 0x0000, 0x0008, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
746c321187Smrg   0x0008, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, /* 15 */
756c321187Smrg   0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x000c};
766c321187Smrg
776c321187Smrg/* maps Cyrillic keysyms to 8859-5 */
786c321187Smrgstatic unsigned char _Xconst cyrillic[128] =
796c321187Smrg   {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
806c321187Smrg    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
816c321187Smrg    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
826c321187Smrg    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
836c321187Smrg    0x00, 0xf2, 0xf3, 0xf1, 0xf4, 0xf5, 0xf6, 0xf7, /* 10 */
846c321187Smrg    0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0x00, 0xfe, 0xff,
856c321187Smrg    0xf0, 0xa2, 0xa3, 0xa1, 0xa4, 0xa5, 0xa6, 0xa7, /* 11 */
866c321187Smrg    0xa8, 0xa9, 0xaa, 0xab, 0xac, 0x00, 0xae, 0xaf,
876c321187Smrg    0xee, 0xd0, 0xd1, 0xe6, 0xd4, 0xd5, 0xe4, 0xd3, /* 12 */
886c321187Smrg    0xe5, 0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0xdd, 0xde,
896c321187Smrg    0xdf, 0xef, 0xe0, 0xe1, 0xe2, 0xe3, 0xd6, 0xd2, /* 13 */
906c321187Smrg    0xec, 0xeb, 0xd7, 0xe8, 0xed, 0xe9, 0xe7, 0xea,
916c321187Smrg    0xce, 0xb0, 0xb1, 0xc6, 0xb4, 0xb5, 0xc4, 0xb3, /* 14 */
926c321187Smrg    0xc5, 0xb8, 0xb9, 0xba, 0xbb, 0xbc, 0xbd, 0xbe,
936c321187Smrg    0xbf, 0xcf, 0xc0, 0xc1, 0xc2, 0xc3, 0xb6, 0xb2, /* 15 */
946c321187Smrg    0xcc, 0xcb, 0xb7, 0xc8, 0xcd, 0xc9, 0xc7, 0xca};
956c321187Smrg
966c321187Smrg/* maps Greek keysyms to 8859-7 */
976c321187Smrgstatic unsigned char _Xconst greek[128] =
986c321187Smrg   {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
996c321187Smrg    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
1006c321187Smrg    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
1016c321187Smrg    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
1026c321187Smrg    0x00, 0xb6, 0xb8, 0xb9, 0xba, 0xda, 0x00, 0xbc, /* 10 */
1036c321187Smrg    0xbe, 0xdb, 0x00, 0xbf, 0x00, 0x00, 0xb5, 0xaf,
1046c321187Smrg    0x00, 0xdc, 0xdd, 0xde, 0xdf, 0xfa, 0xc0, 0xfc, /* 11 */
1056c321187Smrg    0xfd, 0xfb, 0xe0, 0xfe, 0x00, 0x00, 0x00, 0x00,
1066c321187Smrg    0x00, 0xc1, 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7, /* 12 */
1076c321187Smrg    0xc8, 0xc9, 0xca, 0xcb, 0xcc, 0xcd, 0xce, 0xcf,
1086c321187Smrg    0xd0, 0xd1, 0xd3, 0x00, 0xd4, 0xd5, 0xd6, 0xd7, /* 13 */
1096c321187Smrg    0xd8, 0xd9, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
1106c321187Smrg    0x00, 0xe1, 0xe2, 0xe3, 0xe4, 0xe5, 0xe6, 0xe7, /* 14 */
1116c321187Smrg    0xe8, 0xe9, 0xea, 0xeb, 0xec, 0xed, 0xee, 0xef,
1126c321187Smrg    0xf0, 0xf1, 0xf3, 0xf2, 0xf4, 0xf5, 0xf6, 0xf7, /* 15 */
1136c321187Smrg    0xf8, 0xf9, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
1146c321187Smrg
1156c321187Smrg#define sLatin1		(unsigned long)0
1166c321187Smrg#define sLatin2		(unsigned long)1
1176c321187Smrg#define sLatin3		(unsigned long)2
1186c321187Smrg#define sLatin4		(unsigned long)3
1196c321187Smrg#define sKana		(unsigned long)4
1206c321187Smrg#define sX0201		(unsigned long)0x01000004
1216c321187Smrg#define sArabic		(unsigned long)5
1226c321187Smrg#define sCyrillic	(unsigned long)6
1236c321187Smrg#define sGreek		(unsigned long)7
1246c321187Smrg#define sAPL		(unsigned long)11
1256c321187Smrg#define sHebrew		(unsigned long)12
1266c321187Smrg
1276c321187Smrgint
1286c321187SmrgXmuLookupString(register XKeyEvent *event, unsigned char *buffer, int nbytes,
1296c321187Smrg		KeySym *keysym, XComposeStatus *status,
1306c321187Smrg		unsigned long keysymSet)
1316c321187Smrg{
1326c321187Smrg    int count;
1336c321187Smrg    KeySym symbol;
1346c321187Smrg    unsigned long kset;
1356c321187Smrg
1366c321187Smrg    kset = keysymSet & 0xffffff;
1376c321187Smrg    count = XLookupString(event, (char *)buffer, nbytes, &symbol, status);
1386c321187Smrg    if (keysym) *keysym = symbol;
1396c321187Smrg    if ((nbytes == 0) || (symbol == NoSymbol)) {
1406c321187Smrg	/* nothing */
1416c321187Smrg    } else if ((count == 0) && ((symbol >> 8) == kset)) {
1426c321187Smrg	count = 1;
1436c321187Smrg	switch (keysymSet) {
1446c321187Smrg	case sKana:
1456c321187Smrg	    buffer[0] = (symbol & 0xff);
1466c321187Smrg	    if (buffer[0] == 0x7e)
1476c321187Smrg		count = 0;
1486c321187Smrg	    break;
1496c321187Smrg	case sCyrillic:
1506c321187Smrg	    buffer[0] = cyrillic[symbol & 0x7f];
1516c321187Smrg	    break;
1526c321187Smrg	case sGreek:
1536c321187Smrg	    buffer[0] = greek[symbol & 0x7f];
1546c321187Smrg	    if (!buffer[0])
1556c321187Smrg		count = 0;
1566c321187Smrg	    break;
1576c321187Smrg	default:
1586c321187Smrg	    buffer[0] = (symbol & 0xff);
1596c321187Smrg	    break;
1606c321187Smrg	}
1616c321187Smrg    } else if ((keysymSet != 0) && (count == 1) &&
1626c321187Smrg	       (((unsigned char *)buffer)[0] == symbol) &&
1636c321187Smrg	       (symbol & 0x80) &&
1646c321187Smrg	       !(latin1[symbol & 0x7f] & (1 << kset))) {
1656c321187Smrg	if ((keysymSet == sHebrew) && (symbol == XK_multiply))
1666c321187Smrg	    buffer[0] = 0xaa;
1676c321187Smrg	else if ((keysymSet == sHebrew) && (symbol == XK_division))
1686c321187Smrg	    buffer[0] = 0xba;
1696c321187Smrg	else if ((keysymSet == sCyrillic) && (symbol == XK_section))
1706c321187Smrg	    buffer[0] = 0xfd;
1716c321187Smrg	else if ((keysymSet == sX0201) && (symbol == XK_yen))
1726c321187Smrg	    buffer[0] = 0x5c;
1736c321187Smrg	else
1746c321187Smrg	    count = 0;
1756c321187Smrg    } else if (count != 0) {
1766c321187Smrg	if ((keysymSet == sX0201) &&
1776c321187Smrg	    ((symbol == XK_backslash) || (symbol == XK_asciitilde)))
1786c321187Smrg	    count = 0;
1796c321187Smrg    } else if (((symbol >> 8) == sLatin2) &&
1806c321187Smrg	       (symbol & 0x80) && (latin2[symbol & 0x7f] & (1 << kset))) {
1816c321187Smrg	buffer[0] = (symbol & 0xff);
1826c321187Smrg	count = 1;
1836c321187Smrg    } else if ((keysymSet == sGreek) &&
1846c321187Smrg	       ((symbol == XK_leftsinglequotemark) ||
1856c321187Smrg		(symbol == XK_rightsinglequotemark))) {
1866c321187Smrg	buffer[0] = symbol - (XK_leftsinglequotemark - 0xa1);
1876c321187Smrg	count = 1;
1886c321187Smrg    }
1896c321187Smrg    return count;
1906c321187Smrg}
1916c321187Smrg
1926c321187Smrg/* produces ISO 8859-1 encoding plus ASCII control */
1936c321187Smrgint
1946c321187SmrgXmuLookupLatin1(register XKeyEvent *event, unsigned char *buffer, int nbytes,
1956c321187Smrg		KeySym *keysym, XComposeStatus *status)
1966c321187Smrg{
1976c321187Smrg    return XLookupString(event, (char *)buffer, nbytes, keysym, status);
1986c321187Smrg}
1996c321187Smrg
2006c321187Smrg/* produces ISO 8859-2 encoding plus ASCII control */
2016c321187Smrgint
2026c321187SmrgXmuLookupLatin2(register XKeyEvent *event, unsigned char *buffer, int nbytes,
2036c321187Smrg		KeySym *keysym, XComposeStatus *status)
2046c321187Smrg{
2056c321187Smrg    return XmuLookupString(event, buffer, nbytes, keysym, status, sLatin2);
2066c321187Smrg}
2076c321187Smrg
2086c321187Smrg/* produces ISO 8859-3 encoding plus ASCII control */
2096c321187Smrgint
2106c321187SmrgXmuLookupLatin3(register XKeyEvent *event, unsigned char *buffer, int nbytes,
2116c321187Smrg		KeySym *keysym, XComposeStatus *status)
2126c321187Smrg{
2136c321187Smrg    return XmuLookupString(event, buffer, nbytes, keysym, status, sLatin3);
2146c321187Smrg}
2156c321187Smrg
2166c321187Smrg/* produces ISO 8859-4 encoding plus ASCII control */
2176c321187Smrgint
2186c321187SmrgXmuLookupLatin4(register XKeyEvent *event, unsigned char *buffer, int nbytes,
2196c321187Smrg		KeySym *keysym, XComposeStatus *status)
2206c321187Smrg{
2216c321187Smrg    return XmuLookupString(event, buffer, nbytes, keysym, status, sLatin4);
2226c321187Smrg}
2236c321187Smrg
2246c321187Smrg/* produces ISO 8859-1 GL plus Katakana plus ASCII control */
2256c321187Smrgint
2266c321187SmrgXmuLookupKana(register XKeyEvent *event, unsigned char *buffer, int nbytes,
2276c321187Smrg	      KeySym *keysym, XComposeStatus *status)
2286c321187Smrg{
2296c321187Smrg    return XmuLookupString(event, buffer, nbytes, keysym, status, sKana);
2306c321187Smrg}
2316c321187Smrg
2326c321187Smrg/* produces JIS X0201-1976 (8-bit) */
2336c321187Smrgint
2346c321187SmrgXmuLookupJISX0201(register XKeyEvent *event, unsigned char *buffer, int nbytes,
2356c321187Smrg		  KeySym *keysym, XComposeStatus *status)
2366c321187Smrg{
2376c321187Smrg    return XmuLookupString(event, buffer, nbytes, keysym, status, sX0201);
2386c321187Smrg}
2396c321187Smrg
2406c321187Smrg/* produces ISO 8859-6 encoding plus ASCII control */
2416c321187Smrgint
2426c321187SmrgXmuLookupArabic(register XKeyEvent *event, unsigned char *buffer, int nbytes,
2436c321187Smrg		KeySym *keysym, XComposeStatus *status)
2446c321187Smrg{
2456c321187Smrg    return XmuLookupString(event, buffer, nbytes, keysym, status, sArabic);
2466c321187Smrg}
2476c321187Smrg
2486c321187Smrg/* produces ISO/IEC 8859-5 encoding plus ASCII control */
2496c321187Smrgint
2506c321187SmrgXmuLookupCyrillic(register XKeyEvent *event, unsigned char *buffer, int nbytes,
2516c321187Smrg		  KeySym *keysym, XComposeStatus *status)
2526c321187Smrg{
2536c321187Smrg    return XmuLookupString(event, buffer, nbytes, keysym, status, sCyrillic);
2546c321187Smrg}
2556c321187Smrg
2566c321187Smrg/* produces ISO 8859-7 encoding plus ASCII control */
2576c321187Smrgint
2586c321187SmrgXmuLookupGreek(register XKeyEvent *event, unsigned char *buffer, int nbytes,
2596c321187Smrg	       KeySym *keysym, XComposeStatus *status)
2606c321187Smrg{
2616c321187Smrg    return XmuLookupString(event, buffer, nbytes, keysym, status, sGreek);
2626c321187Smrg}
2636c321187Smrg
2646c321187Smrg/* XXX this character set needs work */
2656c321187Smrg
2666c321187Smrgint
2676c321187SmrgXmuLookupAPL(register XKeyEvent *event, unsigned char *buffer, int nbytes,
2686c321187Smrg	     KeySym *keysym, XComposeStatus *status)
2696c321187Smrg{
2706c321187Smrg    return XmuLookupString(event, buffer, nbytes, keysym, status, sAPL);
2716c321187Smrg}
2726c321187Smrg
2736c321187Smrg/* produces ISO 8859-8 encoding plus ASCII control */
2746c321187Smrgint
2756c321187SmrgXmuLookupHebrew(register XKeyEvent *event, unsigned char *buffer, int nbytes,
2766c321187Smrg		KeySym *keysym, XComposeStatus *status)
2776c321187Smrg{
2786c321187Smrg    return XmuLookupString(event, buffer, nbytes, keysym, status, sHebrew);
2796c321187Smrg}
280