shlwapi: Last parameter in SHUnicodeToAnsiCP is an int.
This commit is contained in:
parent
1daf40a837
commit
2e19130976
|
@ -215,7 +215,7 @@
|
||||||
215 stdcall -noname SHAnsiToUnicode(str ptr long)
|
215 stdcall -noname SHAnsiToUnicode(str ptr long)
|
||||||
216 stdcall -noname SHAnsiToUnicodeCP(long str ptr long)
|
216 stdcall -noname SHAnsiToUnicodeCP(long str ptr long)
|
||||||
217 stdcall -noname SHUnicodeToAnsi(wstr ptr ptr)
|
217 stdcall -noname SHUnicodeToAnsi(wstr ptr ptr)
|
||||||
218 stdcall -noname SHUnicodeToAnsiCP(long wstr ptr ptr)
|
218 stdcall -noname SHUnicodeToAnsiCP(long wstr ptr long)
|
||||||
219 stdcall -noname QISearch(long long long long)
|
219 stdcall -noname QISearch(long long long long)
|
||||||
220 stdcall -noname SHSetDefaultDialogFont(ptr long)
|
220 stdcall -noname SHSetDefaultDialogFont(ptr long)
|
||||||
221 stdcall -noname SHRemoveDefaultDialogFont(ptr)
|
221 stdcall -noname SHRemoveDefaultDialogFont(ptr)
|
||||||
|
|
|
@ -2477,20 +2477,24 @@ DWORD WINAPI SHAnsiToUnicode(LPCSTR lpSrcStr, LPWSTR lpDstStr, int iLen)
|
||||||
* CodePage [I] Code page to use for the conversion
|
* CodePage [I] Code page to use for the conversion
|
||||||
* lpSrcStr [I] Source Unicode string to convert
|
* lpSrcStr [I] Source Unicode string to convert
|
||||||
* lpDstStr [O] Destination for converted Ascii string
|
* lpDstStr [O] Destination for converted Ascii string
|
||||||
* lpiLen [I/O] Input length of lpDstStr/destination for length of lpDstStr
|
* dstlen [I] Length of buffer at lpDstStr
|
||||||
*
|
*
|
||||||
* RETURNS
|
* RETURNS
|
||||||
* Success: The number of characters that result from the conversion.
|
* Success: The length in bytes of the result at lpDstStr (including the terminator)
|
||||||
* Failure: 0.
|
* Failure: When using CP_UTF8, CP_UTF7 or 0xc350 as codePage, 0 is returned and
|
||||||
|
* the result is not nul-terminated.
|
||||||
|
* When using a different codepage, the length in bytes of the truncated
|
||||||
|
* result at lpDstStr (including the terminator) is returned and
|
||||||
|
* lpDstStr is always nul-terminated.
|
||||||
|
*
|
||||||
*/
|
*/
|
||||||
INT WINAPI SHUnicodeToAnsiCP(UINT CodePage, LPCWSTR lpSrcStr, LPSTR lpDstStr,
|
DWORD WINAPI SHUnicodeToAnsiCP(UINT CodePage, LPCWSTR lpSrcStr, LPSTR lpDstStr, int dstlen)
|
||||||
LPINT lpiLen)
|
|
||||||
{
|
{
|
||||||
static const WCHAR emptyW[] = { '\0' };
|
static const WCHAR emptyW[] = { '\0' };
|
||||||
int len , reqLen;
|
int len , reqLen;
|
||||||
LPSTR mem;
|
LPSTR mem;
|
||||||
|
|
||||||
if (!lpDstStr || !lpiLen)
|
if (!lpDstStr || !dstlen)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (!lpSrcStr)
|
if (!lpSrcStr)
|
||||||
|
@ -2509,41 +2513,41 @@ INT WINAPI SHUnicodeToAnsiCP(UINT CodePage, LPCWSTR lpSrcStr, LPSTR lpDstStr,
|
||||||
case CP_UTF8:
|
case CP_UTF8:
|
||||||
{
|
{
|
||||||
DWORD dwMode = 0;
|
DWORD dwMode = 0;
|
||||||
INT nWideCharCount = len - 1;
|
INT lenW = len - 1;
|
||||||
|
INT needed = dstlen - 1;
|
||||||
|
HRESULT hr;
|
||||||
|
|
||||||
if (ConvertINetUnicodeToMultiByte(&dwMode, CodePage, lpSrcStr,
|
/* try the user supplied buffer first */
|
||||||
&nWideCharCount, lpDstStr,
|
hr = ConvertINetUnicodeToMultiByte(&dwMode, CodePage, lpSrcStr, &lenW, lpDstStr, &needed);
|
||||||
lpiLen) == S_OK)
|
if (hr == S_OK)
|
||||||
return 0;
|
|
||||||
|
|
||||||
if (nWideCharCount < len - 1)
|
|
||||||
{
|
{
|
||||||
mem = HeapAlloc(GetProcessHeap(), 0, *lpiLen);
|
lpDstStr[needed] = '\0';
|
||||||
|
return needed + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* user buffer too small. exclude termination and copy as much as possible */
|
||||||
|
lenW = len;
|
||||||
|
hr = ConvertINetUnicodeToMultiByte(&dwMode, CodePage, lpSrcStr, &lenW, NULL, &needed);
|
||||||
|
needed++;
|
||||||
|
mem = HeapAlloc(GetProcessHeap(), 0, needed);
|
||||||
if (!mem)
|
if (!mem)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
*lpiLen = 0;
|
hr = ConvertINetUnicodeToMultiByte(&dwMode, CodePage, lpSrcStr, &len, mem, &needed);
|
||||||
|
if (hr == S_OK)
|
||||||
if (ConvertINetUnicodeToMultiByte(&dwMode, CodePage, lpSrcStr, &len,
|
|
||||||
mem, lpiLen) != S_OK)
|
|
||||||
{
|
{
|
||||||
SHTruncateString(mem, *lpiLen);
|
reqLen = SHTruncateString(mem, dstlen);
|
||||||
lstrcpynA(lpDstStr, mem, *lpiLen + 1);
|
if (reqLen > 0) memcpy(lpDstStr, mem, reqLen-1);
|
||||||
HeapFree(GetProcessHeap(), 0, mem);
|
|
||||||
return *lpiLen + 1;
|
|
||||||
}
|
}
|
||||||
HeapFree(GetProcessHeap(), 0, mem);
|
HeapFree(GetProcessHeap(), 0, mem);
|
||||||
return *lpiLen;
|
return 0;
|
||||||
}
|
|
||||||
lpDstStr[*lpiLen] = '\0';
|
|
||||||
return *lpiLen;
|
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
reqLen = WideCharToMultiByte(CodePage, 0, lpSrcStr, len, lpDstStr,
|
/* try the user supplied buffer first */
|
||||||
*lpiLen, NULL, NULL);
|
reqLen = WideCharToMultiByte(CodePage, 0, lpSrcStr, len, lpDstStr, dstlen, NULL, NULL);
|
||||||
|
|
||||||
if (!reqLen && GetLastError() == ERROR_INSUFFICIENT_BUFFER)
|
if (!reqLen && GetLastError() == ERROR_INSUFFICIENT_BUFFER)
|
||||||
{
|
{
|
||||||
|
@ -2556,12 +2560,12 @@ INT WINAPI SHUnicodeToAnsiCP(UINT CodePage, LPCWSTR lpSrcStr, LPSTR lpDstStr,
|
||||||
reqLen = WideCharToMultiByte(CodePage, 0, lpSrcStr, len, mem,
|
reqLen = WideCharToMultiByte(CodePage, 0, lpSrcStr, len, mem,
|
||||||
reqLen, NULL, NULL);
|
reqLen, NULL, NULL);
|
||||||
|
|
||||||
reqLen = SHTruncateString(mem, *lpiLen);
|
reqLen = SHTruncateString(mem, dstlen -1);
|
||||||
reqLen++;
|
reqLen++;
|
||||||
|
|
||||||
lstrcpynA(lpDstStr, mem, *lpiLen);
|
lstrcpynA(lpDstStr, mem, reqLen);
|
||||||
|
|
||||||
HeapFree(GetProcessHeap(), 0, mem);
|
HeapFree(GetProcessHeap(), 0, mem);
|
||||||
|
lpDstStr[reqLen-1] = '\0';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2586,9 +2590,7 @@ INT WINAPI SHUnicodeToAnsiCP(UINT CodePage, LPCWSTR lpSrcStr, LPSTR lpDstStr,
|
||||||
*/
|
*/
|
||||||
INT WINAPI SHUnicodeToAnsi(LPCWSTR lpSrcStr, LPSTR lpDstStr, INT iLen)
|
INT WINAPI SHUnicodeToAnsi(LPCWSTR lpSrcStr, LPSTR lpDstStr, INT iLen)
|
||||||
{
|
{
|
||||||
INT myint = iLen;
|
return SHUnicodeToAnsiCP(CP_ACP, lpSrcStr, lpDstStr, iLen);
|
||||||
|
|
||||||
return SHUnicodeToAnsiCP(CP_ACP, lpSrcStr, lpDstStr, &myint);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
|
|
Loading…
Reference in New Issue