SetLocale.c revision b4ee4795
11ab64890Smrg 21ab64890Smrg/* 31ab64890Smrg * Copyright 1990, 1991 by OMRON Corporation, NTT Software Corporation, 41ab64890Smrg * and Nippon Telegraph and Telephone Corporation 51ab64890Smrg * 61ab64890Smrg * Permission to use, copy, modify, distribute, and sell this software and its 71ab64890Smrg * documentation for any purpose is hereby granted without fee, provided that 81ab64890Smrg * the above copyright notice appear in all copies and that both that 91ab64890Smrg * copyright notice and this permission notice appear in supporting 101ab64890Smrg * documentation, and that the names of OMRON, NTT Software, and NTT 111ab64890Smrg * not be used in advertising or publicity pertaining to distribution of the 121ab64890Smrg * software without specific, written prior permission. OMRON, NTT Software, 131ab64890Smrg * and NTT make no representations about the suitability of this 141ab64890Smrg * software for any purpose. It is provided "as is" without express or 151ab64890Smrg * implied warranty. 161ab64890Smrg * 171ab64890Smrg * OMRON, NTT SOFTWARE, AND NTT, DISCLAIM ALL WARRANTIES WITH REGARD 181ab64890Smrg * TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY 191ab64890Smrg * AND FITNESS, IN NO EVENT SHALL OMRON, NTT SOFTWARE, OR NTT, BE 2061b2299dSmrg * LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 211ab64890Smrg * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 221ab64890Smrg * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 231ab64890Smrg * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 241ab64890Smrg * 251ab64890Smrg * Authors: Li Yuhong OMRON Corporation 261ab64890Smrg * Tetsuya Kato NTT Software Corporation 271ab64890Smrg * Hiroshi Kuribayashi OMRON Corporation 2861b2299dSmrg * 291ab64890Smrg */ 301ab64890Smrg/* 311ab64890Smrg 321ab64890SmrgCopyright 1987,1998 The Open Group 331ab64890Smrg 341ab64890SmrgPermission to use, copy, modify, distribute, and sell this software and its 351ab64890Smrgdocumentation for any purpose is hereby granted without fee, provided that 361ab64890Smrgthe above copyright notice appear in all copies and that both that 371ab64890Smrgcopyright notice and this permission notice appear in supporting 381ab64890Smrgdocumentation. 391ab64890Smrg 401ab64890SmrgThe above copyright notice and this permission notice shall be included 411ab64890Smrgin all copies or substantial portions of the Software. 421ab64890Smrg 431ab64890SmrgTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 441ab64890SmrgOR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 451ab64890SmrgMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 461ab64890SmrgIN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR 471ab64890SmrgOTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 481ab64890SmrgARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 491ab64890SmrgOTHER DEALINGS IN THE SOFTWARE. 501ab64890Smrg 511ab64890SmrgExcept as contained in this notice, the name of The Open Group shall 521ab64890Smrgnot be used in advertising or otherwise to promote the sale, use or 531ab64890Smrgother dealings in this Software without prior written authorization 541ab64890Smrgfrom The Open Group. 551ab64890Smrg 561ab64890Smrg*/ 571ab64890Smrg 581ab64890Smrg#ifdef HAVE_CONFIG_H 591ab64890Smrg#include <config.h> 601ab64890Smrg#endif 611ab64890Smrg#include "Xlibint.h" 621ab64890Smrg#include "Xlcint.h" 631ab64890Smrg#include <X11/Xlocale.h> 641ab64890Smrg#include <X11/Xos.h> 651ab64890Smrg#include "XlcPubI.h" 661ab64890Smrg 671ab64890Smrg#define MAXLOCALE 64 /* buffer size of locale name */ 681ab64890Smrg 691ab64890Smrg#ifdef X_LOCALE 701ab64890Smrg 711ab64890Smrg/* alternative setlocale() for when the OS does not provide one */ 721ab64890Smrg 731ab64890Smrgchar * 741ab64890Smrg_Xsetlocale( 751ab64890Smrg int category, 761ab64890Smrg _Xconst char *name 771ab64890Smrg) 781ab64890Smrg{ 791ab64890Smrg static char *xsl_name; 801ab64890Smrg char *old_name; 811ab64890Smrg XrmMethods methods; 821ab64890Smrg XPointer state; 831ab64890Smrg 841ab64890Smrg if (category != LC_CTYPE && category != LC_ALL) 851ab64890Smrg return NULL; 861ab64890Smrg if (!name) { 871ab64890Smrg if (xsl_name) 881ab64890Smrg return xsl_name; 891ab64890Smrg return "C"; 901ab64890Smrg } 911ab64890Smrg if (!*name) 921ab64890Smrg name = getenv("LC_CTYPE"); 931ab64890Smrg if (!name || !*name) 941ab64890Smrg name = getenv("LANG"); 951ab64890Smrg if (name && strlen(name) >= MAXLOCALE) 961ab64890Smrg name = NULL; 971ab64890Smrg if (!name || !*name || !_XOpenLC((char *) name)) 981ab64890Smrg name = "C"; 991ab64890Smrg old_name = xsl_name; 1001ab64890Smrg xsl_name = (char *)name; 1011ab64890Smrg methods = _XrmInitParseInfo(&state); 1021ab64890Smrg xsl_name = old_name; 1031ab64890Smrg if (!methods) 1041ab64890Smrg return NULL; 1051ab64890Smrg name = (*methods->lcname)(state); 1061ab64890Smrg xsl_name = Xmalloc(strlen(name) + 1); 1071ab64890Smrg if (!xsl_name) { 1081ab64890Smrg xsl_name = old_name; 1091ab64890Smrg (*methods->destroy)(state); 1101ab64890Smrg return NULL; 1111ab64890Smrg } 1121ab64890Smrg strcpy(xsl_name, name); 1131ab64890Smrg if (old_name) 1141ab64890Smrg Xfree(old_name); 1151ab64890Smrg (*methods->destroy)(state); 1161ab64890Smrg return xsl_name; 1171ab64890Smrg} 1181ab64890Smrg 1191ab64890Smrg#else /* X_LOCALE */ 1201ab64890Smrg 121b4ee4795Smrg#if defined(__APPLE__) || defined(__CYGWIN__) 1221ab64890Smrgchar * 1231ab64890Smrg_Xsetlocale( 1241ab64890Smrg int category, 1251ab64890Smrg _Xconst char *name 1261ab64890Smrg) 1271ab64890Smrg{ 1281ab64890Smrg return setlocale(category, name); 1291ab64890Smrg} 130b4ee4795Smrg#endif /* __APPLE__ || __CYGWIN__ */ 1311ab64890Smrg 1321ab64890Smrg/* 1331ab64890Smrg * _XlcMapOSLocaleName is an implementation dependent routine that derives 1341ab64890Smrg * the LC_CTYPE locale name as used in the sample implementation from that 1351ab64890Smrg * returned by setlocale. 1361ab64890Smrg * 1371ab64890Smrg * Should match the code in Xt ExtractLocaleName. 13861b2299dSmrg * 1391ab64890Smrg * This function name is a bit of a misnomer. Even the siname parameter 14061b2299dSmrg * name is a misnomer. On most modern operating systems this function is 14161b2299dSmrg * a no-op, simply returning the osname; but on older operating systems 14261b2299dSmrg * like Ultrix, or HPUX 9.x and earlier, when you set LANG=german.88591 14361b2299dSmrg * then the string returned by setlocale(LC_ALL, "") will look something 1441ab64890Smrg * like: "german.88591 german.88591 ... german.88591". Then this function 1451ab64890Smrg * will pick out the LC_CTYPE component and return a pointer to that. 1461ab64890Smrg */ 1471ab64890Smrg 1481ab64890Smrgchar * 1491ab64890Smrg_XlcMapOSLocaleName( 1501ab64890Smrg char *osname, 1511ab64890Smrg char *siname) 1521ab64890Smrg{ 1531ab64890Smrg#if defined(hpux) || defined(CSRG_BASED) || defined(sun) || defined(SVR4) || defined(sgi) || defined(__osf__) || defined(AIXV3) || defined(ultrix) || defined(WIN32) || defined(__UNIXOS2__) || defined(linux) 1541ab64890Smrg# ifdef hpux 1551ab64890Smrg# ifndef _LastCategory 1561ab64890Smrg /* HPUX 9 and earlier */ 1571ab64890Smrg# define SKIPCOUNT 2 1581ab64890Smrg# define STARTCHAR ':' 1591ab64890Smrg# define ENDCHAR ';' 1601ab64890Smrg# else 1611ab64890Smrg /* HPUX 10 */ 1621ab64890Smrg# define ENDCHAR ' ' 1631ab64890Smrg# endif 1641ab64890Smrg# else 1651ab64890Smrg# ifdef ultrix 1661ab64890Smrg# define SKIPCOUNT 2 1671ab64890Smrg# define STARTCHAR '\001' 1681ab64890Smrg# define ENDCHAR '\001' 1691ab64890Smrg# else 1701ab64890Smrg# if defined(WIN32) || defined(__UNIXOS2__) 1711ab64890Smrg# define SKIPCOUNT 1 1721ab64890Smrg# define STARTCHAR '=' 1731ab64890Smrg# define ENDCHAR ';' 1741ab64890Smrg# define WHITEFILL 1751ab64890Smrg# else 1761ab64890Smrg# if defined(__osf__) || (defined(AIXV3) && !defined(AIXV4)) 1771ab64890Smrg# define STARTCHAR ' ' 1781ab64890Smrg# define ENDCHAR ' ' 1791ab64890Smrg# else 1801ab64890Smrg# if defined(linux) 1811ab64890Smrg# define STARTSTR "LC_CTYPE=" 1821ab64890Smrg# define ENDCHAR ';' 1831ab64890Smrg# else 1841ab64890Smrg# if !defined(sun) || defined(SVR4) 1851ab64890Smrg# define STARTCHAR '/' 1861ab64890Smrg# define ENDCHAR '/' 1871ab64890Smrg# endif 1881ab64890Smrg# endif 1891ab64890Smrg# endif 1901ab64890Smrg# endif 1911ab64890Smrg# endif 1921ab64890Smrg# endif 1931ab64890Smrg 1941ab64890Smrg char *start; 1951ab64890Smrg char *end; 1961ab64890Smrg int len; 1971ab64890Smrg# ifdef SKIPCOUNT 1981ab64890Smrg int n; 1991ab64890Smrg# endif 2001ab64890Smrg 2011ab64890Smrg start = osname; 2021ab64890Smrg# ifdef SKIPCOUNT 2031ab64890Smrg for (n = SKIPCOUNT; 2041ab64890Smrg --n >= 0 && start && (start = strchr (start, STARTCHAR)); 2051ab64890Smrg start++) 2061ab64890Smrg ; 2071ab64890Smrg if (!start) 2081ab64890Smrg start = osname; 2091ab64890Smrg# endif 2101ab64890Smrg# ifdef STARTCHAR 21161b2299dSmrg if (start && (start = strchr (start, STARTCHAR))) 2121ab64890Smrg# elif defined (STARTSTR) 2131ab64890Smrg if (start && (start = strstr (start,STARTSTR))) 2141ab64890Smrg# endif 2151ab64890Smrg { 2161ab64890Smrg# ifdef STARTCHAR 2171ab64890Smrg start++; 2181ab64890Smrg# elif defined (STARTSTR) 2191ab64890Smrg start += strlen(STARTSTR); 2201ab64890Smrg# endif 2211ab64890Smrg if ((end = strchr (start, ENDCHAR))) { 2221ab64890Smrg len = end - start; 2231ab64890Smrg if (len >= MAXLOCALE) 2241ab64890Smrg len = MAXLOCALE - 1; 2251ab64890Smrg strncpy(siname, start, len); 2261ab64890Smrg *(siname + len) = '\0'; 2271ab64890Smrg# ifdef WHITEFILL 2281ab64890Smrg for (start = siname; start = strchr(start, ' '); ) 2291ab64890Smrg *start++ = '-'; 2301ab64890Smrg# endif 2311ab64890Smrg return siname; 2321ab64890Smrg } else /* if no ENDCHAR is found we are at the end of the line */ 2331ab64890Smrg return start; 2341ab64890Smrg } 2351ab64890Smrg# ifdef WHITEFILL 2361ab64890Smrg if (strchr(osname, ' ')) { 2371ab64890Smrg len = strlen(osname); 2381ab64890Smrg if (len >= MAXLOCALE - 1) 2391ab64890Smrg len = MAXLOCALE - 1; 2401ab64890Smrg strncpy(siname, osname, len); 2411ab64890Smrg *(siname + len) = '\0'; 2421ab64890Smrg for (start = siname; start = strchr(start, ' '); ) 2431ab64890Smrg *start++ = '-'; 2441ab64890Smrg return siname; 2451ab64890Smrg } 2461ab64890Smrg# endif 2471ab64890Smrg# undef STARTCHAR 2481ab64890Smrg# undef ENDCHAR 2491ab64890Smrg# undef WHITEFILL 2501ab64890Smrg#endif 2511ab64890Smrg return osname; 2521ab64890Smrg} 2531ab64890Smrg 2541ab64890Smrg#endif /* X_LOCALE */ 255