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