mirror of
https://github.com/reactos/reactos.git
synced 2025-08-03 14:25:52 +00:00
[KERNEL32]: In failure cases we should return one more byte for ANSI_NULL as well. Also fix another length check.
svn path=/trunk/; revision=54279
This commit is contained in:
parent
5ef1d7f8d2
commit
5671dd839b
1 changed files with 6 additions and 8 deletions
|
@ -457,8 +457,8 @@ ExpandEnvironmentStringsA(IN LPCSTR lpSrc,
|
|||
Status = RtlExpandEnvironmentStrings_U(NULL, &SourceU, &DestU, &Length);
|
||||
if (NT_SUCCESS(Status))
|
||||
{
|
||||
/* Get the ASCII length of the variable */
|
||||
Result = RtlUnicodeStringToAnsiSize(&DestU);
|
||||
/* Get the ASCII length of the variable, add a byte for NULL */
|
||||
Result = RtlUnicodeStringToAnsiSize(&DestU) + sizeof(ANSI_NULL);
|
||||
}
|
||||
}
|
||||
else
|
||||
|
@ -475,16 +475,14 @@ ExpandEnvironmentStringsA(IN LPCSTR lpSrc,
|
|||
|
||||
/* Check the size */
|
||||
Result = RtlUnicodeStringToAnsiSize(&DestU);
|
||||
if (Result <= nSize)
|
||||
if (Result <= UniSize)
|
||||
{
|
||||
/* Convert the string */
|
||||
RtlInitEmptyAnsiString(&Dest, lpDst, UniSize);
|
||||
Status = RtlUnicodeStringToAnsiString(&Dest, &DestU, FALSE);
|
||||
if (!NT_SUCCESS(Status))
|
||||
{
|
||||
/* Clear the destination */
|
||||
*lpDst = ANSI_NULL;
|
||||
}
|
||||
|
||||
/* Write a NULL-char in case of failure only */
|
||||
if (!NT_SUCCESS(Status)) *lpDst = ANSI_NULL;
|
||||
}
|
||||
}
|
||||
Quickie:
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue