Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

170 lines
5.3 KiB

/***
*wcsupr.c - routine to map lower-case characters in a wchar_t string
* to upper-case
*
* Copyright (c) 1985-2001, Microsoft Corporation. All rights reserved.
*
*Purpose:
* Converts all the lower case characters in a wchar_t string
* to upper case, in place.
*
*Revision History:
* 09-09-91 ETC Created from strupr.c and wcslwr.c
* 04-06-92 KRS Make work without _INTL also.
* 08-19-92 KRS Activate NLS support.
* 08-22-92 SRW Allow INTL definition to be conditional for building ntcrt.lib
* 09-02-92 SRW Get _INTL definition via ..\crt32.def
* 02-16-93 CFW Optimize test for lowercase in "C" locale.
* 04-06-93 SKS Replace _CRTAPI* with __cdecl
* 06-02-93 SRW ignore _INTL if _NTSUBSET_ defined.
* 09-15-93 CFW Use ANSI conformant "__" names.
* 09-16-93 GJF Merged NT SDK and Cuda versions.
* 09-22-93 CFW Use __crtxxx internal NLS API wrapper.
* 11-09-93 CFW Add code page for __crtxxx().
* 02-07-94 CFW POSIXify.
* 09-06-94 CFW Remove _INTL switch.
* 10-25-94 GJF Sped up C locale, multi-thread case.
* 01-10-95 CFW Debug CRT allocs.
* 09-26-95 GJF New locking macro, and scheme, for functions which
* reference the locale.
* 08-17-98 GJF Revised multithread support based on threadlocinfo
* struct. Also, use _alloca instead of _malloc_crt if
* possible.
* 10-19-98 GJF Major typo, = should have been ==
* 12-10-99 GB Added support for recovery from stack overflow around
* _alloca().
*
*******************************************************************************/
#ifndef _POSIX_
#include <cruntime.h>
#include <string.h>
#include <malloc.h>
#include <locale.h>
#include <ctype.h>
#include <setlocal.h>
#include <mtdll.h>
#include <awint.h>
#include <dbgint.h>
/***
*wchar_t *_wcsupr(string) - map lower-case characters in a string to upper-case
*
*Purpose:
* wcsupr converts lower-case characters in a null-terminated wchar_t
* string to their upper-case equivalents. The result may be longer or
* shorter than the original string. Assumes enough space in string
* to hold the result.
*
*Entry:
* wchar_t *wsrc - wchar_t string to change to upper case
*
*Exit:
* input string address
*
*Exceptions:
* on an error, the original string is unaltered
*
*******************************************************************************/
wchar_t * __cdecl _wcsupr (
wchar_t * wsrc
)
{
#ifndef _NTSUBSET_
wchar_t *p; /* traverses string for C locale conversion */
wchar_t *wdst; /* wide version of string in alternate case */
int dstlen; /* len of wdst string, wide chars, with null */
int malloc_flag = 0;
#ifdef _MT
pthreadlocinfo ptloci = _getptd()->ptlocinfo;
if ( ptloci != __ptlocinfo )
ptloci = __updatetlocinfo();
if ( ptloci->lc_handle[LC_CTYPE] == _CLOCALEHANDLE ) {
#else
if ( __lc_handle[LC_CTYPE] == _CLOCALEHANDLE ) {
#endif
for ( p = wsrc ; *p ; p++ )
{
if ( (*p >= (wchar_t)L'a') && (*p <= (wchar_t)L'z') )
*p = *p - (L'a' - L'A');
}
return(wsrc);
} /* C locale */
/* Inquire size of wdst string */
#ifdef _MT
if ( (dstlen = __crtLCMapStringW( ptloci->lc_handle[LC_CTYPE],
#else
if ( (dstlen = __crtLCMapStringW( __lc_handle[LC_CTYPE],
#endif
LCMAP_UPPERCASE,
wsrc,
-1,
NULL,
0,
#ifdef _MT
ptloci->lc_codepage )) == 0 )
#else
__lc_codepage )) == 0 )
#endif
return(wsrc);
/* Allocate space for wdst */
__try {
wdst = (wchar_t *)_alloca(dstlen * sizeof(wchar_t));
}
__except( EXCEPTION_EXECUTE_HANDLER ) {
_resetstkoflw();
wdst = NULL;
}
if ( wdst == NULL ) {
wdst = (wchar_t *)_malloc_crt(dstlen * sizeof(wchar_t));
malloc_flag++;
}
/* Map wrc string to wide-character wdst string in alternate case */
if ( (wdst != NULL) &&
#ifdef _MT
(__crtLCMapStringW( ptloci->lc_handle[LC_CTYPE],
#else
(__crtLCMapStringW( __lc_handle[LC_CTYPE],
#endif
LCMAP_UPPERCASE,
wsrc,
-1,
wdst,
dstlen,
#ifdef _MT
ptloci->lc_codepage ) != 0) )
#else
__lc_codepage ) != 0) )
#endif
/* Copy wdst string to user string */
wcscpy (wsrc, wdst);
if ( malloc_flag )
_free_crt(wdst);
#else
wchar_t * p;
for (p=wsrc; *p; ++p)
{
if (L'a' <= *p && *p <= L'z')
*p += (wchar_t)(L'A' - L'a');
}
#endif
return(wsrc);
}
#endif /* _POSIX_ */