mirror of https://github.com/tongzx/nt5src
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.
298 lines
5.0 KiB
298 lines
5.0 KiB
//---------------------------------------------------------------------------
|
|
//
|
|
// Microsoft Windows
|
|
// Copyright (C) Microsoft Corporation, 1992 - 1995
|
|
//
|
|
// File: sconv.cxx
|
|
//
|
|
// Contents: Ansi to Unicode conversions
|
|
//
|
|
// History: KrishnaG Jan 22 1996
|
|
//----------------------------------------------------------------------------
|
|
#include "nds.hxx"
|
|
#pragma hdrstop
|
|
|
|
int
|
|
AnsiToUnicodeString(
|
|
LPSTR pAnsi,
|
|
LPWSTR pUnicode,
|
|
DWORD StringLength
|
|
)
|
|
{
|
|
int iReturn;
|
|
|
|
if( StringLength == NULL_TERMINATED )
|
|
StringLength = strlen( pAnsi );
|
|
|
|
iReturn = MultiByteToWideChar(CP_ACP,
|
|
MB_PRECOMPOSED,
|
|
pAnsi,
|
|
StringLength + 1,
|
|
pUnicode,
|
|
StringLength + 1 );
|
|
|
|
//
|
|
// Ensure NULL termination.
|
|
//
|
|
pUnicode[StringLength] = 0;
|
|
|
|
return iReturn;
|
|
}
|
|
|
|
|
|
int
|
|
UnicodeToAnsiString(
|
|
LPWSTR pUnicode,
|
|
LPSTR pAnsi,
|
|
DWORD StringLength
|
|
)
|
|
{
|
|
LPSTR pTempBuf = NULL;
|
|
INT rc = 0;
|
|
|
|
if( StringLength == NULL_TERMINATED ) {
|
|
|
|
//
|
|
// StringLength is just the
|
|
// number of characters in the string
|
|
//
|
|
StringLength = wcslen( pUnicode );
|
|
}
|
|
|
|
//
|
|
// Include one for the NULL
|
|
//
|
|
StringLength++;
|
|
|
|
//
|
|
// Unfortunately, WideCharToMultiByte doesn't do conversion in place,
|
|
// so allocate a temporary buffer, which we can then copy:
|
|
//
|
|
|
|
if( pAnsi == (LPSTR)pUnicode )
|
|
{
|
|
pTempBuf = (LPSTR)AllocADsMem( StringLength );
|
|
pAnsi = pTempBuf;
|
|
}
|
|
|
|
if( pAnsi )
|
|
{
|
|
rc = WideCharToMultiByte( CP_ACP,
|
|
0,
|
|
pUnicode,
|
|
StringLength,
|
|
pAnsi,
|
|
StringLength,
|
|
NULL,
|
|
NULL );
|
|
}
|
|
|
|
//
|
|
// Null terminate
|
|
//
|
|
pAnsi[StringLength-1] = 0;
|
|
|
|
/* If pTempBuf is non-null, we must copy the resulting string
|
|
* so that it looks as if we did it in place:
|
|
*/
|
|
if( pTempBuf && ( rc > 0 ) )
|
|
{
|
|
pAnsi = (LPSTR)pUnicode;
|
|
strcpy( pAnsi, pTempBuf );
|
|
LocalFree( pTempBuf );
|
|
}
|
|
|
|
return rc;
|
|
}
|
|
|
|
|
|
LPWSTR
|
|
AllocateUnicodeString(
|
|
LPSTR pAnsiString
|
|
)
|
|
{
|
|
LPWSTR pUnicodeString = NULL;
|
|
|
|
if (!pAnsiString)
|
|
return NULL;
|
|
|
|
pUnicodeString = (LPWSTR)AllocADsMem(
|
|
strlen(pAnsiString)*sizeof(WCHAR) +sizeof(WCHAR)
|
|
);
|
|
|
|
if (pUnicodeString) {
|
|
|
|
AnsiToUnicodeString(
|
|
pAnsiString,
|
|
pUnicodeString,
|
|
NULL_TERMINATED
|
|
);
|
|
}
|
|
|
|
return pUnicodeString;
|
|
}
|
|
|
|
|
|
void
|
|
FreeUnicodeString(
|
|
LPWSTR pUnicodeString
|
|
)
|
|
{
|
|
if (!pUnicodeString)
|
|
return;
|
|
|
|
LocalFree(pUnicodeString);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
LPSTR
|
|
AllocateAnsiString(
|
|
LPWSTR pUnicodeString
|
|
)
|
|
{
|
|
LPSTR pAnsiString = NULL;
|
|
|
|
if (!pUnicodeString)
|
|
return NULL;
|
|
|
|
pAnsiString = (LPSTR) AllocADsMem(
|
|
wcslen(pUnicodeString)*sizeof(CHAR) +sizeof(CHAR)
|
|
);
|
|
|
|
if (pAnsiString) {
|
|
|
|
UnicodeToAnsiString(
|
|
pUnicodeString,
|
|
pAnsiString,
|
|
NULL_TERMINATED
|
|
);
|
|
}
|
|
|
|
return pAnsiString;
|
|
}
|
|
|
|
|
|
void
|
|
FreeAnsiString(
|
|
LPSTR pAnsiString
|
|
)
|
|
{
|
|
if (!pAnsiString)
|
|
return;
|
|
|
|
LocalFree(pAnsiString);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
LPSTR*
|
|
AllocateAnsiStringArray(
|
|
LPWSTR *ppUnicodeStrings,
|
|
DWORD dwNumElements
|
|
)
|
|
{
|
|
LPSTR *ppAnsiStrings = NULL;
|
|
DWORD i, j;
|
|
|
|
if (ppUnicodeStrings && dwNumElements) {
|
|
ppAnsiStrings = (LPSTR *) AllocADsMem(sizeof(LPSTR) * dwNumElements);
|
|
|
|
if (!ppAnsiStrings) {
|
|
goto error;
|
|
}
|
|
|
|
for (i=0; i < dwNumElements; i++) {
|
|
|
|
ppAnsiStrings[i] = AllocateAnsiString(ppUnicodeStrings[i]);
|
|
|
|
if (!ppAnsiStrings[i]) {
|
|
|
|
for (j=0; j<i; j++)
|
|
FreeADsMem(ppAnsiStrings[j]);
|
|
|
|
FreeADsMem(ppAnsiStrings);
|
|
|
|
goto error;
|
|
|
|
}
|
|
}
|
|
}
|
|
|
|
return ppAnsiStrings;
|
|
|
|
error:
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
void
|
|
FreeAnsiStringArray(
|
|
LPSTR *ppAnsiStrings,
|
|
DWORD dwNumElements
|
|
)
|
|
{
|
|
DWORD i;
|
|
|
|
if (!ppAnsiStrings) {
|
|
return;
|
|
}
|
|
|
|
for (i=0; i < dwNumElements; i++) {
|
|
FreeADsMem(ppAnsiStrings[i]);
|
|
}
|
|
|
|
FreeADsMem(ppAnsiStrings);
|
|
}
|
|
|
|
|
|
|
|
|
|
DWORD
|
|
ComputeMaxStrlenW(
|
|
LPWSTR pString,
|
|
DWORD cchBufMax
|
|
)
|
|
{
|
|
DWORD cchLen;
|
|
|
|
//
|
|
// Include space for the NULL.
|
|
//
|
|
|
|
cchBufMax--;
|
|
|
|
cchLen = wcslen(pString);
|
|
|
|
if (cchLen > cchBufMax)
|
|
return cchBufMax;
|
|
|
|
return cchLen;
|
|
}
|
|
|
|
|
|
DWORD
|
|
ComputeMaxStrlenA(
|
|
LPSTR pString,
|
|
DWORD cchBufMax
|
|
)
|
|
{
|
|
DWORD cchLen;
|
|
|
|
//
|
|
// Include space for the NULL.
|
|
//
|
|
cchBufMax--;
|
|
|
|
cchLen = lstrlenA(pString);
|
|
|
|
if (cchLen > cchBufMax)
|
|
return cchBufMax;
|
|
|
|
return cchLen;
|
|
}
|
|
|
|
|