source: trunk/src/kernel32/lang.cpp@ 5471

Last change on this file since 5471 was 5471, checked in by sandervl, 24 years ago

removed asciitounicode* & unicodetoascii functions

File size: 33.4 KB
Line 
1/* $Id: lang.cpp,v 1.33 2001-04-04 09:00:58 sandervl Exp $ */
2/*
3 * Win32 language API functions for OS/2
4 *
5 * Copyright 1998 Sander van Leeuwen
6 * Copyright 1998 Patrick Haller
7 * Copyright 1999 Przemyslaw Dobrowolski
8 *
9 *
10 * Project Odin Software License can be found in LICENSE.TXT
11 *
12 */
13#include <os2win.h>
14#include <winnls.h>
15#include <stdlib.h>
16#include <stdio.h>
17#include <string.h>
18#include <odinwrap.h>
19#include <heapstring.h>
20#include <win\winreg.h>
21#include <winos2def.h>
22#include "unicode.h"
23#include "oslibmisc.h"
24#include <wprocess.h>
25#include <uniconv.h>
26
27#define DBG_LOCALLOG DBG_lang
28#include "dbglocal.h"
29
30ODINDEBUGCHANNEL(KERNEL32-LANG)
31
32static ULONG defaultLanguage = 0;
33//******************************************************************************
34//******************************************************************************
35ULONG GetLanguageId()
36{
37 if(defaultLanguage == 0) {
38 switch(OSLibQueryCountry()) {
39 case CC_USA:
40 defaultLanguage = MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_US);
41 break;
42 case CC_CANADA:
43 defaultLanguage = MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_US);
44 break;
45 case CC_LATIN_AMERICA:
46 defaultLanguage = MAKELANGID(LANG_SPANISH, SUBLANG_SPANISH);
47 break;
48 case CC_GREECE:
49 defaultLanguage = MAKELANGID(LANG_GREEK, SUBLANG_DEFAULT);
50 break;
51 case CC_NETHERLANDS:
52 defaultLanguage = MAKELANGID(LANG_DUTCH, SUBLANG_DUTCH);
53 break;
54 case CC_BELGIUM:
55 defaultLanguage = MAKELANGID(LANG_DUTCH, SUBLANG_DUTCH_BELGIAN);
56 break;
57 case CC_FRANCE:
58 defaultLanguage = MAKELANGID(LANG_FRENCH, SUBLANG_FRENCH);
59 break;
60 case CC_SPAIN:
61 defaultLanguage = MAKELANGID(LANG_SPANISH, SUBLANG_SPANISH);
62 break;
63 case CC_ITALY:
64 defaultLanguage = MAKELANGID(LANG_ITALIAN, SUBLANG_ITALIAN);
65 break;
66 case CC_SWITZERLAND:
67 defaultLanguage = MAKELANGID(LANG_GERMAN, SUBLANG_GERMAN_SWISS);
68 break;
69 case CC_AUSTRIA:
70 defaultLanguage = MAKELANGID(LANG_GERMAN, SUBLANG_GERMAN_AUSTRIAN);
71 break;
72 case CC_UNITED_KINGDOM:
73 defaultLanguage = MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_UK);
74 break;
75 case CC_DENMARK:
76 defaultLanguage = MAKELANGID(LANG_DANISH, SUBLANG_DEFAULT);
77 break;
78 case CC_SWEDEN:
79 defaultLanguage = MAKELANGID(LANG_SWEDISH, SUBLANG_DEFAULT);
80 break;
81 case CC_NORWAY:
82 defaultLanguage = MAKELANGID(LANG_NORWEGIAN, SUBLANG_DEFAULT);
83 break;
84 case CC_WEST_GERMANY:
85 defaultLanguage = MAKELANGID(LANG_GERMAN, SUBLANG_GERMAN);
86 break;
87 case CC_MEXICO:
88 defaultLanguage = MAKELANGID(LANG_SPANISH, SUBLANG_SPANISH_MEXICAN);
89 break;
90 case CC_BRAZIL:
91 defaultLanguage = MAKELANGID(LANG_PORTUGUESE, SUBLANG_PORTUGUESE_BRAZILIAN);
92 break;
93 case CC_AUSTRALIA:
94 defaultLanguage = MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_AUS);
95 break;
96 case CC_NEW_ZEALAND:
97 defaultLanguage = MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_NZ);
98 break;
99 case CC_JAPAN:
100 defaultLanguage = MAKELANGID(LANG_JAPANESE, SUBLANG_DEFAULT);
101 break;
102 case CC_KOREA:
103 defaultLanguage = MAKELANGID(LANG_KOREAN, SUBLANG_DEFAULT);
104 break;
105 case CC_CHINA:
106 defaultLanguage = MAKELANGID(LANG_CHINESE, SUBLANG_CHINESE_TRADITIONAL);
107 break;
108 case CC_TAIWAN:
109 defaultLanguage = MAKELANGID(LANG_CHINESE, SUBLANG_CHINESE_TRADITIONAL);
110 break;
111 case CC_TURKEY:
112 defaultLanguage = MAKELANGID(LANG_TURKISH, SUBLANG_DEFAULT);
113 break;
114 case CC_PORTUGAL:
115 defaultLanguage = MAKELANGID(LANG_PORTUGUESE, SUBLANG_DEFAULT);
116 break;
117 case CC_LUXEMBOURG:
118 defaultLanguage = MAKELANGID(LANG_GERMAN, SUBLANG_GERMAN_LUXEMBOURG);
119 break;
120 case CC_ICELAND:
121 defaultLanguage = MAKELANGID(LANG_ICELANDIC, SUBLANG_DEFAULT);
122 break;
123 case CC_FINLAND:
124 defaultLanguage = MAKELANGID(LANG_FINNISH, SUBLANG_DEFAULT);
125 break;
126 case CC_CZECH_REPUBLIC:
127 defaultLanguage = MAKELANGID(LANG_CZECH, SUBLANG_DEFAULT);
128 break;
129 case CC_SLOVAK_REPUBLIC:
130 defaultLanguage = MAKELANGID(LANG_SLOVAK, SUBLANG_DEFAULT);
131 break;
132 case CC_POLAND:
133 defaultLanguage = MAKELANGID(LANG_POLISH, SUBLANG_DEFAULT);
134 break;
135 default:
136 defaultLanguage = MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_UK);
137 break;
138 }
139 }
140 return defaultLanguage;
141}
142//******************************************************************************
143//******************************************************************************
144LCID WIN32API GetUserDefaultLCID(void)
145{
146 dprintf2(("KERNEL32: GetUserDefaultLCID: returns %x", MAKELCID(GetLanguageId(), SORT_DEFAULT)));
147 return(MAKELCID(GetLanguageId(), SORT_DEFAULT));
148}
149//******************************************************************************
150//******************************************************************************
151LCID WIN32API GetSystemDefaultLCID(void)
152{
153 dprintf2(("KERNEL32: GetSystemDefaultLCID: returns %x", GetUserDefaultLCID()));
154 return GetUserDefaultLCID();
155}
156//******************************************************************************
157//******************************************************************************
158LANGID WIN32API GetUserDefaultLangID()
159{
160 dprintf2(("KERNEL32: GetUserDefaultLangID, returns %x", GetLanguageId()));
161 return(GetLanguageId());
162}
163//******************************************************************************
164//******************************************************************************
165LANGID WIN32API GetSystemDefaultLangID(void)
166{
167 dprintf2(("KERNEL32: GetSystemDefaultLangID returns %x", GetUserDefaultLangID()));
168 return GetUserDefaultLangID();
169}
170
171//******************************************************************************
172//******************************************************************************
173static BOOL LocaleFromUniStr(LPWSTR lpUniStr, LPWSTR wbuf, ULONG *pLen)
174{
175 if (wbuf)
176 {
177 if (*pLen > UniStrlen(lpUniStr))
178 UniStrcpy(wbuf,lpUniStr);
179 else
180 {
181 SetLastError(ERROR_INSUFFICIENT_BUFFER);
182 *pLen=0;
183 return FALSE;
184 }
185 }
186
187 *pLen=UniStrlen(lpUniStr)+1; // + null terminator
188
189 return TRUE;
190}
191//******************************************************************************
192//******************************************************************************
193static BOOL LocaleFromUniChar(WCHAR wcUniChar, LPWSTR wbuf, ULONG *pLen)
194{
195 if (wbuf)
196 {
197// if (*pLen >= sizeof(WCHAR))
198 if (*pLen >= 2)
199 {
200 wbuf[0]=(WCHAR)'0'+wcUniChar;
201 wbuf[1]=0;
202 }
203 else
204 {
205 SetLastError(ERROR_INSUFFICIENT_BUFFER);
206 *pLen=0;
207 return FALSE;
208 }
209 }
210
211 *pLen=2;
212
213 return TRUE;
214}
215
216/*****************************************************************************
217 * Name : DWORD GetLocaleInfoW
218 * Purpose : The GetLocaleInfoW function returns specific locale information
219 * Parameters: LCID lcid locale identifier
220 * LCTYPE LCType type of information
221 * LPSTRW wbuf address of buffer for information
222 * int len size of buffer
223 * Variables :
224 * Result : size of target buffer
225 * Remark : In this version LOCALE_SYSTEM_DEFAULT == LOCALE_USER_DEFAULT
226 *
227 * LOCALE_STHOUSAND - with some languages returns OS/2 separator not Windows!
228 * LOCALE_IMEASURE - return '0' like English US
229 * LOCALE_INEGNUMBER - return '1' like English US
230 * LOCALE_ICURRDIGITS - return '2' like English US
231 * LOCALE_IDATE are identical as LOCALE_ILDATE (must be fixed?)
232 * LOCALE_SGROUPING and
233 * LOCALE_SMONGROUPING are tested only with Polish & English languages
234 * LOCALE_SMONTHNAME13 and
235 * LOCALE_SABBERVMONTHNAME13 - returns empty string like English US
236 * LOCALE_FONTSIGNATURE - return empty string like English US
237 *
238 * Status : FULLY TESTED
239 *
240 * Author : Przemyslaw Dobrowolski [Tue, 1999/07/22 17:07]
241 *****************************************************************************/
242ODINFUNCTION4(int, GetLocaleInfoW, LCID, lcid, LCTYPE, LCType, LPWSTR, wbuf,
243 int, len)
244{
245 LocaleObject locale_object = NULL;
246 struct UniLconv *puni_lconv = NULL;
247 WCHAR *pInfoItem;
248 int rc;
249 COUNTRYCODE Country = {0};
250 COUNTRYINFO CtryInfo = {0};
251 ULONG ulInfoLen = 0;
252
253 dprintf(("KERNEL32: OS2GetLocaleInfoW lcID=%d,lcType=%x,wbuf=%X,len=%d\n",lcid,LCType,wbuf,len));
254
255 if (len && (! wbuf) )
256 {
257 SetLastError(ERROR_INSUFFICIENT_BUFFER);
258 return 0;
259 }
260
261 if (wbuf) *wbuf==0;
262
263 rc=UniCreateLocaleObject(UNI_UCS_STRING_POINTER,(UniChar *)L"", &locale_object);
264
265 if ( rc == ULS_SUCCESS )
266 {
267 UniQueryLocaleInfo(locale_object, &puni_lconv);
268
269 DosQueryCtryInfo(sizeof(COUNTRYINFO), &Country, &CtryInfo, &ulInfoLen);
270
271 ulInfoLen = len; // Now we use this variable as returned length info
272
273 LCType &= ~(LOCALE_NOUSEROVERRIDE|LOCALE_USE_CP_ACP);
274
275 switch(LCType)
276 {
277 case LOCALE_SDECIMAL:
278 LocaleFromUniStr(puni_lconv->decimal_point,wbuf,&ulInfoLen);
279 break;
280
281 case LOCALE_IMEASURE: // Fixme!
282 // only like English US
283 LocaleFromUniChar(0,wbuf,&ulInfoLen);
284 break;
285
286 case LOCALE_INEGNUMBER: // Fixme!
287 // only like English US
288 LocaleFromUniChar(1,wbuf,&ulInfoLen);
289 break;
290
291 case LOCALE_ICURRDIGITS:// Fixme!
292 // only like English US
293 LocaleFromUniChar(2,wbuf,&ulInfoLen);
294 break;
295
296 case LOCALE_STHOUSAND:
297 LocaleFromUniStr(puni_lconv->thousands_sep,wbuf,&ulInfoLen);
298 //MN: hack for Czech language; weird value returned here (0xA0 instead of 0x20)
299 if(defaultLanguage == CC_CZECH_REPUBLIC) {
300 ((BYTE*)wbuf)[0] = ((BYTE*)wbuf)[0] & 0x7F;
301 }
302 break;
303
304 case LOCALE_SGROUPING: // tested only with Polish & English
305 if (wbuf)
306 {
307 if (puni_lconv->grouping)
308 {
309 if (len >= 3*sizeof(WCHAR))
310 {
311 wbuf[0]='0'+*puni_lconv->grouping;
312 wbuf[1]=(WCHAR)';';
313 wbuf[2]=(WCHAR)'0';
314 wbuf[3]=0;
315 ulInfoLen=4;
316 }
317 else
318 {
319 SetLastError(ERROR_INSUFFICIENT_BUFFER);
320 break;
321 }
322 }
323 else
324 {
325 wbuf[0]=20; // Windows return space!!
326 ulInfoLen=2;
327 }
328 }
329 else
330 ulInfoLen=2;
331 break;
332
333 case LOCALE_SMONGROUPING: // tested only with Polish & English
334 if (wbuf)
335 {
336 if (puni_lconv->mon_grouping)
337 {
338 if (len >= 3*sizeof(WCHAR))
339 {
340 wbuf[0]='0'+*puni_lconv->mon_grouping;
341 wbuf[1]=(WCHAR)';';
342 wbuf[2]=(WCHAR)'0';
343 wbuf[3]=0;
344 ulInfoLen=4;
345 }
346 else
347 {
348 SetLastError(ERROR_INSUFFICIENT_BUFFER);
349 break;
350 }
351 }
352 else
353 {
354 wbuf[0]=20; // Windows return space!!
355 ulInfoLen=2;
356 }
357 }
358 else
359 ulInfoLen=2;
360 break;
361
362
363 case LOCALE_SCURRENCY:
364 LocaleFromUniStr(puni_lconv->currency_symbol,wbuf,&ulInfoLen);
365 break;
366
367 case LOCALE_SMONDECIMALSEP:
368 LocaleFromUniStr(puni_lconv->mon_decimal_point,wbuf,&ulInfoLen);
369 break;
370
371 case LOCALE_SMONTHOUSANDSEP:
372 LocaleFromUniStr(puni_lconv->mon_thousands_sep,wbuf,&ulInfoLen);
373 break;
374
375 case LOCALE_SPOSITIVESIGN:
376 LocaleFromUniStr(puni_lconv->positive_sign,wbuf,&ulInfoLen);
377 break;
378
379 case LOCALE_SNEGATIVESIGN:
380 LocaleFromUniStr(puni_lconv->negative_sign,wbuf,&ulInfoLen);
381 break;
382
383 case LOCALE_IPOSSIGNPOSN:
384 LocaleFromUniChar(puni_lconv->p_sign_posn,wbuf,&ulInfoLen);
385 break;
386
387 case LOCALE_INEGSIGNPOSN:
388 LocaleFromUniChar(puni_lconv->n_sign_posn,wbuf,&ulInfoLen);
389 break;
390
391 case LOCALE_IPOSSYMPRECEDES:
392 LocaleFromUniChar(puni_lconv->p_cs_precedes,wbuf,&ulInfoLen);
393 break;
394
395 case LOCALE_IPOSSEPBYSPACE:
396 LocaleFromUniChar(puni_lconv->p_sep_by_space,wbuf,&ulInfoLen);
397 break;
398
399 case LOCALE_INEGSYMPRECEDES:
400 LocaleFromUniChar(puni_lconv->n_cs_precedes,wbuf,&ulInfoLen);
401 break;
402
403 case LOCALE_INEGSEPBYSPACE:
404 LocaleFromUniChar(puni_lconv->n_sep_by_space,wbuf,&ulInfoLen);
405 break;
406
407 case LOCALE_S1159:
408 UniQueryLocaleItem(locale_object, AM_STR,&pInfoItem);
409 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
410 UniFreeMem(pInfoItem);
411 break;
412
413 case LOCALE_S2359:
414 UniQueryLocaleItem(locale_object, PM_STR,&pInfoItem);
415 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
416 UniFreeMem(pInfoItem);
417 break;
418
419 case LOCALE_IDEFAULTLANGUAGE:
420 case LOCALE_ILANGUAGE:
421 UniQueryLocaleItem(locale_object, XWINLOCALE,&pInfoItem);
422 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
423 UniFreeMem(pInfoItem);
424 break;
425
426 case LOCALE_INEGCURR:
427 UniQueryLocaleItem(locale_object, INEGCURR,&pInfoItem);
428 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
429 UniFreeMem(pInfoItem);
430 break;
431
432 case LOCALE_ICURRENCY:
433 UniQueryLocaleItem(locale_object, ICURRENCY,&pInfoItem);
434 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
435 UniFreeMem(pInfoItem);
436 break;
437
438
439
440 case LOCALE_SNATIVELANGNAME:
441 case LOCALE_SLANGUAGE:
442 UniQueryLocaleItem(locale_object, SLANGUAGE,&pInfoItem);
443 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
444 UniFreeMem(pInfoItem);
445 break;
446
447 case LOCALE_SABBREVLANGNAME:
448 UniQueryLocaleItem(locale_object, SABBREVLANGNAME,&pInfoItem);
449 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
450 UniFreeMem(pInfoItem);
451 break;
452
453 case LOCALE_IDEFAULTCOUNTRY:
454 case LOCALE_ICOUNTRY:
455 UniQueryLocaleItem(locale_object, ICOUNTRY,&pInfoItem);
456 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
457 UniFreeMem(pInfoItem);
458 break;
459
460 case LOCALE_SENGLANGUAGE:
461 UniQueryLocaleItem(locale_object, SENGLANGUAGE,&pInfoItem);
462 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
463 UniFreeMem(pInfoItem);
464 break;
465
466 case LOCALE_SENGCOUNTRY:
467 case LOCALE_SCOUNTRY:
468 UniQueryLocaleItem(locale_object, SENGCOUNTRYNAME,&pInfoItem);
469 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
470 UniFreeMem(pInfoItem);
471 break;
472
473 case LOCALE_SABBREVCTRYNAME:
474 UniQueryLocaleItem(locale_object, SABBREVCTRYNAME,&pInfoItem);
475 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
476 UniFreeMem(pInfoItem);
477 break;
478
479 case LOCALE_SNATIVECTRYNAME:
480 UniQueryLocaleItem(locale_object, SCOUNTRY,&pInfoItem);
481 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
482 UniFreeMem(pInfoItem);
483 break;
484
485 case LOCALE_SNATIVEDIGITS:
486 UniQueryLocaleItem(locale_object, SNATIVEDIGITS,&pInfoItem);
487 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
488 UniFreeMem(pInfoItem);
489 break;
490
491
492 case LOCALE_IDEFAULTCODEPAGE:
493 UniQueryLocaleItem(locale_object, ICODEPAGE,&pInfoItem);
494 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
495 UniFreeMem(pInfoItem);
496 break;
497
498 case LOCALE_IDEFAULTANSICODEPAGE:
499 UniQueryLocaleItem(locale_object, IANSICODEPAGE,&pInfoItem);
500 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
501 UniFreeMem(pInfoItem);
502 break;
503
504 case LOCALE_IDEFAULTMACCODEPAGE:
505 UniQueryLocaleItem(locale_object, IMACCODEPAGE,&pInfoItem);
506 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
507 UniFreeMem(pInfoItem);
508 break;
509
510 case LOCALE_SLIST:
511 UniQueryLocaleItem(locale_object, LISTSEP,&pInfoItem);
512 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
513 UniFreeMem(pInfoItem);
514 break;
515
516 case LOCALE_SINTLSYMBOL:
517 UniQueryLocaleItem(locale_object, SINTLSYMBOL,&pInfoItem);
518 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
519 UniFreeMem(pInfoItem);
520 break;
521
522 case LOCALE_SDAYNAME7:
523 UniQueryLocaleItem(locale_object, DAY_1,&pInfoItem);
524 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
525 UniFreeMem(pInfoItem);
526 break;
527
528 case LOCALE_SDAYNAME1:
529 UniQueryLocaleItem(locale_object, DAY_2,&pInfoItem);
530 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
531 UniFreeMem(pInfoItem);
532 break;
533
534 case LOCALE_SDAYNAME2:
535 UniQueryLocaleItem(locale_object, DAY_3,&pInfoItem);
536 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
537 UniFreeMem(pInfoItem);
538 break;
539
540 case LOCALE_SDAYNAME3:
541 UniQueryLocaleItem(locale_object, DAY_4,&pInfoItem);
542 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
543 UniFreeMem(pInfoItem);
544 break;
545
546 case LOCALE_SDAYNAME4:
547 UniQueryLocaleItem(locale_object, DAY_5,&pInfoItem);
548 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
549 UniFreeMem(pInfoItem);
550 break;
551
552 case LOCALE_SDAYNAME5:
553 UniQueryLocaleItem(locale_object, DAY_6,&pInfoItem);
554 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
555 UniFreeMem(pInfoItem);
556 break;
557
558 case LOCALE_SDAYNAME6:
559 UniQueryLocaleItem(locale_object, DAY_7,&pInfoItem);
560 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
561 UniFreeMem(pInfoItem);
562 break;
563
564 case LOCALE_SABBREVDAYNAME7:
565 UniQueryLocaleItem(locale_object, ABDAY_1,&pInfoItem);
566 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
567 UniFreeMem(pInfoItem);
568 break;
569
570 case LOCALE_SABBREVDAYNAME1:
571 UniQueryLocaleItem(locale_object, ABDAY_2,&pInfoItem);
572 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
573 UniFreeMem(pInfoItem);
574 break;
575
576 case LOCALE_SABBREVDAYNAME2:
577 UniQueryLocaleItem(locale_object, ABDAY_3,&pInfoItem);
578 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
579 UniFreeMem(pInfoItem);
580 break;
581
582 case LOCALE_SABBREVDAYNAME3:
583 UniQueryLocaleItem(locale_object, ABDAY_4,&pInfoItem);
584 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
585 UniFreeMem(pInfoItem);
586 break;
587
588 case LOCALE_SABBREVDAYNAME4:
589 UniQueryLocaleItem(locale_object, ABDAY_5,&pInfoItem);
590 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
591 UniFreeMem(pInfoItem);
592 break;
593
594 case LOCALE_SABBREVDAYNAME5:
595 UniQueryLocaleItem(locale_object, ABDAY_6,&pInfoItem);
596 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
597 UniFreeMem(pInfoItem);
598 break;
599
600 case LOCALE_SABBREVDAYNAME6:
601 UniQueryLocaleItem(locale_object, ABDAY_7,&pInfoItem);
602 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
603 UniFreeMem(pInfoItem);
604 break;
605
606 case LOCALE_SMONTHNAME1:
607 UniQueryLocaleItem(locale_object, MON_1,&pInfoItem);
608 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
609 UniFreeMem(pInfoItem);
610 break;
611
612 case LOCALE_SMONTHNAME2:
613 UniQueryLocaleItem(locale_object, MON_2,&pInfoItem);
614 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
615 UniFreeMem(pInfoItem);
616 break;
617
618 case LOCALE_SMONTHNAME3:
619 UniQueryLocaleItem(locale_object, MON_3,&pInfoItem);
620 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
621 UniFreeMem(pInfoItem);
622 break;
623
624 case LOCALE_SMONTHNAME4:
625 UniQueryLocaleItem(locale_object, MON_4,&pInfoItem);
626 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
627 UniFreeMem(pInfoItem);
628 break;
629
630 case LOCALE_SMONTHNAME5:
631 UniQueryLocaleItem(locale_object, MON_5,&pInfoItem);
632 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
633 UniFreeMem(pInfoItem);
634 break;
635
636 case LOCALE_SMONTHNAME6:
637 UniQueryLocaleItem(locale_object, MON_6,&pInfoItem);
638 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
639 UniFreeMem(pInfoItem);
640 break;
641
642 case LOCALE_SMONTHNAME7:
643 UniQueryLocaleItem(locale_object, MON_7,&pInfoItem);
644 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
645 UniFreeMem(pInfoItem);
646 break;
647
648 case LOCALE_SMONTHNAME8:
649 UniQueryLocaleItem(locale_object, MON_8,&pInfoItem);
650 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
651 UniFreeMem(pInfoItem);
652 break;
653
654 case LOCALE_SMONTHNAME9:
655 UniQueryLocaleItem(locale_object, MON_9,&pInfoItem);
656 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
657 UniFreeMem(pInfoItem);
658 break;
659
660 case LOCALE_SMONTHNAME10:
661 UniQueryLocaleItem(locale_object, MON_10,&pInfoItem);
662 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
663 UniFreeMem(pInfoItem);
664 break;
665
666 case LOCALE_SMONTHNAME11:
667 UniQueryLocaleItem(locale_object, MON_11,&pInfoItem);
668 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
669 UniFreeMem(pInfoItem);
670 break;
671
672 case LOCALE_SMONTHNAME12:
673 UniQueryLocaleItem(locale_object, MON_12,&pInfoItem);
674 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
675 UniFreeMem(pInfoItem);
676 break;
677
678 case LOCALE_FONTSIGNATURE: // FixMe!!!
679 case LOCALE_SABBREVMONTHNAME13:
680 case LOCALE_SMONTHNAME13:
681 if(wbuf) {
682 *wbuf = 0;
683 }
684 LocaleFromUniStr((LPWSTR)L"\0",wbuf,&ulInfoLen);
685 break;
686
687 case LOCALE_SABBREVMONTHNAME1:
688 UniQueryLocaleItem(locale_object, ABMON_1,&pInfoItem);
689 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
690 UniFreeMem(pInfoItem);
691 break;
692
693 case LOCALE_SABBREVMONTHNAME2:
694 UniQueryLocaleItem(locale_object, ABMON_2,&pInfoItem);
695 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
696 UniFreeMem(pInfoItem);
697 break;
698
699 case LOCALE_SABBREVMONTHNAME3:
700 UniQueryLocaleItem(locale_object, ABMON_3,&pInfoItem);
701 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
702 UniFreeMem(pInfoItem);
703 break;
704
705 case LOCALE_SABBREVMONTHNAME4:
706 UniQueryLocaleItem(locale_object, ABMON_4,&pInfoItem);
707 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
708 UniFreeMem(pInfoItem);
709 break;
710
711 case LOCALE_SABBREVMONTHNAME5:
712 UniQueryLocaleItem(locale_object, ABMON_5,&pInfoItem);
713 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
714 UniFreeMem(pInfoItem);
715 break;
716
717 case LOCALE_SABBREVMONTHNAME6:
718 UniQueryLocaleItem(locale_object, ABMON_6,&pInfoItem);
719 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
720 UniFreeMem(pInfoItem);
721 break;
722
723 case LOCALE_SABBREVMONTHNAME7:
724 UniQueryLocaleItem(locale_object, ABMON_7,&pInfoItem);
725 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
726 UniFreeMem(pInfoItem);
727 break;
728
729 case LOCALE_SABBREVMONTHNAME8:
730 UniQueryLocaleItem(locale_object, ABMON_8,&pInfoItem);
731 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
732 UniFreeMem(pInfoItem);
733 break;
734
735 case LOCALE_SABBREVMONTHNAME9:
736 UniQueryLocaleItem(locale_object, ABMON_9,&pInfoItem);
737 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
738 UniFreeMem(pInfoItem);
739 break;
740
741 case LOCALE_SABBREVMONTHNAME10:
742 UniQueryLocaleItem(locale_object, ABMON_10,&pInfoItem);
743 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
744 UniFreeMem(pInfoItem);
745 break;
746
747 case LOCALE_SABBREVMONTHNAME11:
748 UniQueryLocaleItem(locale_object, ABMON_11,&pInfoItem);
749 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
750 UniFreeMem(pInfoItem);
751 break;
752
753 case LOCALE_SABBREVMONTHNAME12:
754 UniQueryLocaleItem(locale_object, ABMON_12,&pInfoItem);
755 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
756 UniFreeMem(pInfoItem);
757 break;
758
759 case LOCALE_SDATE:
760 UniQueryLocaleItem(locale_object, DATESEP,&pInfoItem);
761 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
762 UniFreeMem(pInfoItem);
763 break;
764
765 case LOCALE_STIME:
766 UniQueryLocaleItem(locale_object, TIMESEP,&pInfoItem);
767 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
768 UniFreeMem(pInfoItem);
769 break;
770
771 case LOCALE_IDATE:
772 case LOCALE_ILDATE:
773 LocaleFromUniChar(CtryInfo.fsDateFmt,wbuf,&ulInfoLen);
774 break;
775
776 case LOCALE_ITIME:
777 UniQueryLocaleItem(locale_object, TIMESEP,&pInfoItem);
778 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
779 UniFreeMem(pInfoItem);
780 break;
781
782 case LOCALE_SSHORTDATE:
783 UniQueryLocaleItem(locale_object, WSHORTDATE,&pInfoItem);
784 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
785 UniFreeMem(pInfoItem);
786 break;
787
788 case LOCALE_SLONGDATE:
789 UniQueryLocaleItem(locale_object, WLONGDATE,&pInfoItem);
790 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
791 UniFreeMem(pInfoItem);
792 break;
793
794
795 case LOCALE_STIMEFORMAT:
796 UniQueryLocaleItem(locale_object, WTIMEFORMAT,&pInfoItem);
797 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
798 UniFreeMem(pInfoItem);
799 break;
800
801 case LOCALE_SISO639LANGNAME:
802 UniQueryLocaleItem(locale_object, SISO639LANGNAME,&pInfoItem);
803 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
804 UniFreeMem(pInfoItem);
805 break;
806
807 case LOCALE_SISO3166CTRYNAME:
808 UniQueryLocaleItem(locale_object, SISO3166CTRYNAME,&pInfoItem);
809 LocaleFromUniStr(pInfoItem,wbuf,&ulInfoLen);
810 UniFreeMem(pInfoItem);
811 break;
812
813 default:
814 dprintf(("KERNEL32: OS2GetLocaleInfoW: LCType %X not yet supported\n", LCType));
815 if (wbuf)
816 {
817 wbuf[0] = (WCHAR) '1';
818 wbuf[1] = 0;
819 }
820 ulInfoLen=2;
821 break;
822
823 }
824 UniFreeLocaleInfo(puni_lconv);
825 UniFreeLocaleObject(locale_object);
826 }
827 else
828 return (0);
829
830 dprintf(("KERNEL32: OS2GetLocaleInfoW returned %d\n",ulInfoLen));
831
832 return (ulInfoLen);
833}
834/*****************************************************************************
835 * Name : DWORD GetLocaleInfoA
836 * Purpose : The GetLocaleInfoA function returns specific locale information
837 * Parameters: LCID lcid locale identifier
838 * LCTYPE LCType type of information
839 * LPSTR buf address of buffer for information
840 * int len size of buffer
841 * Variables :
842 * Result : size of target buffer
843 * Remark : In this version LOCALE_SYSTEM_DEFAULT == LOCALE_USER_DEFAULT
844 * look into GetLocaleInfoW
845 *
846 * Status : TESTED
847 *
848 * Author : Przemyslaw Dobrowolski [Tue, 1999/07/21 12:18]
849 *****************************************************************************/
850ODINFUNCTION4(int, GetLocaleInfoA, LCID, lcid, LCTYPE, LCType, LPSTR, buf,
851 int, len)
852{
853 LPWSTR lpWStr;
854 int ret_len;
855
856 if (len && (! buf) )
857 {
858 SetLastError(ERROR_INSUFFICIENT_BUFFER);
859 return 0;
860 }
861
862 dprintf(("KERNEL32: OS2GetLocaleInfoA lcID=%d,lcType=%x,buf=%X,len=%d\n",lcid,LCType,buf,len));
863
864 if (buf)
865 lpWStr=(LPWSTR)malloc(len*(sizeof(WCHAR)));
866 else
867 lpWStr=NULL; // Query for buffer size
868
869 ret_len = CALL_ODINFUNC(GetLocaleInfoW)(lcid, LCType, lpWStr, len);
870
871 if (ret_len && buf)
872 UnicodeToAscii(lpWStr,buf);
873
874 if (lpWStr) free(lpWStr); // free prevooisly allocated memory
875
876 dprintf(("KERNEL32: OS2GetLocaleInfoA returned %d\n",ret_len));
877
878 return (ret_len);
879}
880//******************************************************************************
881//******************************************************************************
882LCID WIN32API GetThreadLocale()
883{
884 TEB *teb = GetThreadTEB();
885
886 if(teb == NULL) {
887 dprintf(("KERNEL32: ERROR: GetThreadLocale teb == NULL!"));
888 return FALSE;
889 }
890 dprintf(("KERNEL32: GetThreadLocale returned %x", teb->o.odin.lcid));
891 return(teb->o.odin.lcid);
892}
893//******************************************************************************
894//******************************************************************************
895BOOL WIN32API SetThreadLocale(LCID locale)
896{
897 TEB *teb = GetThreadTEB();
898
899 if(teb == NULL) {
900 dprintf(("KERNEL32: ERROR SetThreadLocale teb == NULL!"));
901 return FALSE;
902 }
903 dprintf(("KERNEL32: SetThreadLocale %x", locale));
904 teb->o.odin.lcid = locale;
905 return(TRUE);
906}
907//******************************************************************************
908//******************************************************************************
909
910
911
912#if 0
913PHS: disabled for ole2nls.cpp
914
915/*****************************************************************************
916 * Name : BOOL SetLocaleInfoA
917 * Purpose : The SetLocaleInfoA function sets an item of locale information.
918 * It does so by making an entry in the process portion of the
919 * locale table. This setting only affects the user override portion
920 * of the locale settings; it does not set the system defaults.
921 * Only certain types of locale information, or LCTYPE values, can
922 * be set by this function. See the following Remarks section for a
923 * list of valid LCTYPE values.
924 * The locale information is always passed in as a null-terminated
925 * Unicode string in the Unicode (W) version of the function, and as
926 * a null-terminated ANSI string in the ANSI (A) version. No integers
927 * are allowed by this function; any numeric values must be specified
928 * as Unicode or ANSI text. Each LCTYPE has a particular format, as
929 * noted in Locale Identifiers.
930 * Parameters: LCID Locale locale identifier
931 * LCTYPE LCType type of information to set
932 * LPCTSTR lpLCData pointer to information to set
933 * Variables :
934 * Result : TRUE / FALSE
935 * Remark :
936 * Status : UNTESTED STUB
937 *
938 * Author : Patrick Haller [Mon, 1998/06/15 08:00]
939 *****************************************************************************/
940
941BOOL WIN32API SetLocaleInfoA(LCID Locale,
942 LCTYPE LCType,
943 LPCSTR lpLCData)
944{
945 dprintf(("KERNEL32: SetLocaleInfoA(%08xh,%08xh,%08xh) not implemented.\n",
946 Locale,
947 LCType,
948 lpLCData));
949
950 return (FALSE);
951}
952
953
954/*****************************************************************************
955 * Name : BOOL SetLocaleInfoW
956 * Purpose : The SetLocaleInfoW function sets an item of locale information.
957 * It does so by making an entry in the process portion of the
958 * locale table. This setting only affects the user override portion
959 * of the locale settings; it does not set the system defaults.
960 * Only certain types of locale information, or LCTYPE values, can
961 * be set by this function. See the following Remarks section for a
962 * list of valid LCTYPE values.
963 * The locale information is always passed in as a null-terminated
964 * Unicode string in the Unicode (W) version of the function, and as
965 * a null-terminated ANSI string in the ANSI (A) version. No integers
966 * are allowed by this function; any numeric values must be specified
967 * as Unicode or ANSI text. Each LCTYPE has a particular format, as
968 * noted in Locale Identifiers.
969 * Parameters: LCID Locale locale identifier
970 * LCTYPE LCType type of information to set
971 * LPCTSTR lpLCData pointer to information to set
972 * Variables :
973 * Result : TRUE / FALSE
974 * Remark :
975 * Status : UNTESTED STUB
976 *
977 * Author : Patrick Haller [Mon, 1998/06/15 08:00]
978 *****************************************************************************/
979
980BOOL WIN32API SetLocaleInfoW(LCID Locale,
981 LCTYPE LCType,
982 LPCWSTR lpLCData)
983{
984 dprintf(("KERNEL32: SetLocaleInfoW(%08xh,%08xh,%08xh) not implemented.\n",
985 Locale,
986 LCType,
987 lpLCData));
988
989 return (FALSE);
990}
991
992
993/*****************************************************************************
994 * Name :
995 * Purpose :
996 * Parameters:
997 * Variables :
998 * Result :
999 * Remark :
1000 * Status : UNTESTED STUB
1001 *
1002 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1003 *****************************************************************************/
1004
1005ODINFUNCTION3(DWORD,VerLanguageNameA,DWORD, wLang,
1006 LPSTR, szLang,
1007 DWORD, nSize)
1008{
1009 char buffer[80];
1010 LPCSTR name;
1011 DWORD result;
1012
1013 dprintf(("KERNEL32: VerLanguageNameA not implemented"));
1014
1015 /*
1016 * First, check \System\CurrentControlSet\control\Nls\Locale\<langid>
1017 * from the registry.
1018 */
1019
1020#if 0
1021PHS: disabled because if interlinkage with registry
1022 sprintf( buffer,
1023 "\\System\\CurrentControlSet\\control\\Nls\\Locale\\%08x",
1024 wLang );
1025
1026 result = RegQueryValueA(HKEY_LOCAL_MACHINE,
1027 buffer,
1028 szLang,
1029 (LPLONG)&nSize );
1030 if (result == ERROR_SUCCESS ||
1031 result == ERROR_MORE_DATA)
1032 return nSize;
1033#endif
1034
1035 /*
1036 * If that fails, use the internal table
1037 * (actually, Windows stores the names in a string table resource ...)
1038 */
1039
1040 lstrcpynA(szLang,
1041 "Language-Neutral",
1042 nSize);
1043
1044 return strlen(szLang);
1045}
1046
1047/*****************************************************************************
1048 * Name :
1049 * Purpose :
1050 * Parameters:
1051 * Variables :
1052 * Result :
1053 * Remark :
1054 * Status : UNTESTED STUB
1055 *
1056 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1057 *****************************************************************************/
1058
1059ODINFUNCTION3(DWORD,VerLanguageNameW,DWORD, wLang,
1060 LPWSTR, szLang,
1061 DWORD, nSize)
1062{
1063 LPSTR szLangA;
1064 DWORD rc;
1065
1066 if ( (szLang == NULL) ||
1067 (nSize == 0) ) // validate parameters
1068 return 0;
1069
1070 szLangA = (LPSTR)HEAP_malloc(nSize + 1);
1071 rc = VerLanguageNameA(wLang,
1072 szLangA,
1073 nSize);
1074 if (rc == ERROR_SUCCESS || rc == ERROR_MORE_DATA)
1075 AsciiToUnicodeN(szLangA,
1076 szLang,
1077 nSize);
1078 HEAP_free(szLangA);
1079 return rc;
1080}
1081
1082
1083#endif
Note: See TracBrowser for help on using the repository browser.