fixed GetCurrentDirectoryA() to properly handle the case where the caller only queries the required buffer size.

svn path=/trunk/; revision=13104
This commit is contained in:
Thomas Bluemel 2005-01-17 22:05:00 +00:00
parent d259b9f2fc
commit 2215233073

View file

@ -38,22 +38,30 @@ GetCurrentDirectoryA (
ANSI_STRING AnsiString; ANSI_STRING AnsiString;
UNICODE_STRING UnicodeString; UNICODE_STRING UnicodeString;
/* initialize ansi string */
AnsiString.Length = 0;
AnsiString.MaximumLength = nBufferLength;
AnsiString.Buffer = lpBuffer;
/* allocate buffer for unicode string */ /* allocate buffer for unicode string */
UnicodeString.Length = 0; UnicodeString.Length = 0;
UnicodeString.MaximumLength = nBufferLength * sizeof(WCHAR); UnicodeString.MaximumLength = nBufferLength * sizeof(WCHAR);
if (nBufferLength > 0)
{
UnicodeString.Buffer = RtlAllocateHeap (RtlGetProcessHeap (), UnicodeString.Buffer = RtlAllocateHeap (RtlGetProcessHeap (),
0, 0,
UnicodeString.MaximumLength); UnicodeString.MaximumLength);
/* initialize ansi string */
AnsiString.Length = 0;
AnsiString.MaximumLength = nBufferLength;
AnsiString.Buffer = lpBuffer;
}
else
{
UnicodeString.Buffer = NULL;
}
/* get current directory */ /* get current directory */
UnicodeString.Length = RtlGetCurrentDirectory_U (UnicodeString.MaximumLength, UnicodeString.Length = RtlGetCurrentDirectory_U (UnicodeString.MaximumLength,
UnicodeString.Buffer); UnicodeString.Buffer);
DPRINT("UnicodeString.Buffer %S\n", UnicodeString.Buffer); if (nBufferLength > 0)
{
DPRINT("UnicodeString.Buffer %wZ\n", &UnicodeString);
/* convert unicode string to ansi (or oem) */ /* convert unicode string to ansi (or oem) */
if (bIsFileApiAnsi) if (bIsFileApiAnsi)
@ -70,7 +78,11 @@ GetCurrentDirectoryA (
RtlFreeHeap (RtlGetProcessHeap (), RtlFreeHeap (RtlGetProcessHeap (),
0, 0,
UnicodeString.Buffer); UnicodeString.Buffer);
}
else
{
AnsiString.Length = UnicodeString.Length / sizeof(WCHAR);
}
return AnsiString.Length; return AnsiString.Length;
} }