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