From 742ddb108f0148bb0877db08d7c0a9152ed9f74f Mon Sep 17 00:00:00 2001 From: Filip Navara Date: Sun, 27 Mar 2005 13:03:30 +0000 Subject: [PATCH] Fix memory leak I introduced in revision 14343 and fix buffer size calculation to save 4 bytes. svn path=/trunk/; revision=14349 --- reactos/lib/kernel32/misc/ldr.c | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/reactos/lib/kernel32/misc/ldr.c b/reactos/lib/kernel32/misc/ldr.c index aa2b51a7a8b..1c6f9730ef4 100644 --- a/reactos/lib/kernel32/misc/ldr.c +++ b/reactos/lib/kernel32/misc/ldr.c @@ -56,10 +56,10 @@ GetDllLoadPath(LPCWSTR lpModule) Length = (lpModuleEnd - lpModule) + 1; } - Length += GetCurrentDirectoryW(0, NULL) + 1; - Length += GetSystemDirectoryW(NULL, 0) + 1; - Length += GetWindowsDirectoryW(NULL, 0) + 1; - Length += GetEnvironmentVariableW(L"PATH", NULL, 0) + 1; + Length += GetCurrentDirectoryW(0, NULL); + Length += GetSystemDirectoryW(NULL, 0); + Length += GetWindowsDirectoryW(NULL, 0); + Length += GetEnvironmentVariableW(L"PATH", NULL, 0); EnvironmentBufferW = RtlAllocateHeap(RtlGetProcessHeap(), 0, Length * sizeof(WCHAR)); @@ -181,8 +181,9 @@ LoadLibraryExW ( SearchPath = GetDllLoadPath( dwFlags & LOAD_WITH_ALTERED_SEARCH_PATH ? lpLibFileName : NULL); - RtlInitUnicodeString (&DllName, (LPWSTR)lpLibFileName); + RtlInitUnicodeString(&DllName, (LPWSTR)lpLibFileName); Status = LdrLoadDll(SearchPath, dwFlags, &DllName, (PVOID*)&hInst); + RtlFreeHeap(RtlGetProcessHeap(), 0, SearchPath); if ( !NT_SUCCESS(Status)) { SetLastErrorByStatus (Status);