Commit eed690f9 authored by Vitaliy Margolen's avatar Vitaliy Margolen Committed by Alexandre Julliard

ILFree is not available on all versions.

parent cb7de15e
...@@ -47,12 +47,16 @@ static BOOL (WINAPI *pSHGetSpecialFolderPathW)(HWND, LPWSTR, int, BOOL); ...@@ -47,12 +47,16 @@ static BOOL (WINAPI *pSHGetSpecialFolderPathW)(HWND, LPWSTR, int, BOOL);
static void init_function_pointers(void) static void init_function_pointers(void)
{ {
HMODULE hmod = GetModuleHandleA("shell32.dll"); HMODULE hmod = GetModuleHandleA("shell32.dll");
HRESULT hr;
if(hmod) if(hmod)
{ {
pSHBindToParent = (void*)GetProcAddress(hmod, "SHBindToParent"); pSHBindToParent = (void*)GetProcAddress(hmod, "SHBindToParent");
pSHGetSpecialFolderPathW = (void*)GetProcAddress(hmod, "SHGetSpecialFolderPathW"); pSHGetSpecialFolderPathW = (void*)GetProcAddress(hmod, "SHGetSpecialFolderPathW");
} }
hr = SHGetMalloc(&ppM);
ok(hr == S_OK, "SHGetMalloc failed %08lx\n", hr);
} }
/* creates a file with the specified name for tests */ /* creates a file with the specified name for tests */
...@@ -200,7 +204,7 @@ static void test_BindToObject(void) ...@@ -200,7 +204,7 @@ static void test_BindToObject(void)
hr = IShellFolder_BindToObject(psfDesktop, pidlMyComputer, NULL, &IID_IShellFolder, (LPVOID*)&psfMyComputer); hr = IShellFolder_BindToObject(psfDesktop, pidlMyComputer, NULL, &IID_IShellFolder, (LPVOID*)&psfMyComputer);
ok (SUCCEEDED(hr), "Desktop failed to bind to MyComputer object! hr = %08lx\n", hr); ok (SUCCEEDED(hr), "Desktop failed to bind to MyComputer object! hr = %08lx\n", hr);
IShellFolder_Release(psfDesktop); IShellFolder_Release(psfDesktop);
ILFree(pidlMyComputer); IMalloc_Free(ppM, pidlMyComputer);
if (FAILED(hr)) return; if (FAILED(hr)) return;
hr = IShellFolder_BindToObject(psfMyComputer, pidlEmpty, NULL, &IID_IShellFolder, (LPVOID*)&psfChild); hr = IShellFolder_BindToObject(psfMyComputer, pidlEmpty, NULL, &IID_IShellFolder, (LPVOID*)&psfChild);
...@@ -226,7 +230,7 @@ static void test_BindToObject(void) ...@@ -226,7 +230,7 @@ static void test_BindToObject(void)
hr = IShellFolder_BindToObject(psfMyComputer, pidlSystemDir, NULL, &IID_IShellFolder, (LPVOID*)&psfSystemDir); hr = IShellFolder_BindToObject(psfMyComputer, pidlSystemDir, NULL, &IID_IShellFolder, (LPVOID*)&psfSystemDir);
ok (SUCCEEDED(hr), "MyComputer failed to bind to a FileSystem ShellFolder! hr = %08lx\n", hr); ok (SUCCEEDED(hr), "MyComputer failed to bind to a FileSystem ShellFolder! hr = %08lx\n", hr);
IShellFolder_Release(psfMyComputer); IShellFolder_Release(psfMyComputer);
ILFree(pidlSystemDir); IMalloc_Free(ppM, pidlSystemDir);
if (FAILED(hr)) return; if (FAILED(hr)) return;
hr = IShellFolder_BindToObject(psfSystemDir, pidlEmpty, NULL, &IID_IShellFolder, (LPVOID*)&psfChild); hr = IShellFolder_BindToObject(psfSystemDir, pidlEmpty, NULL, &IID_IShellFolder, (LPVOID*)&psfChild);
...@@ -398,7 +402,7 @@ static void test_CallForAttributes(void) ...@@ -398,7 +402,7 @@ static void test_CallForAttributes(void)
lResult = RegOpenKeyExW(HKEY_CLASSES_ROOT, wszMyDocumentsKey, 0, KEY_WRITE|KEY_READ, &hKey); lResult = RegOpenKeyExW(HKEY_CLASSES_ROOT, wszMyDocumentsKey, 0, KEY_WRITE|KEY_READ, &hKey);
todo_wine { ok (lResult == ERROR_SUCCESS, "RegOpenKeyEx failed! result: %08lx\n", lResult); } todo_wine { ok (lResult == ERROR_SUCCESS, "RegOpenKeyEx failed! result: %08lx\n", lResult); }
if (lResult != ERROR_SUCCESS) { if (lResult != ERROR_SUCCESS) {
ILFree(pidlMyDocuments); IMalloc_Free(ppM, pidlMyDocuments);
IShellFolder_Release(psfDesktop); IShellFolder_Release(psfDesktop);
return; return;
} }
...@@ -409,7 +413,7 @@ static void test_CallForAttributes(void) ...@@ -409,7 +413,7 @@ static void test_CallForAttributes(void)
ok (lResult == ERROR_SUCCESS, "RegQueryValueEx failed! result: %08lx\n", lResult); ok (lResult == ERROR_SUCCESS, "RegQueryValueEx failed! result: %08lx\n", lResult);
if (lResult != ERROR_SUCCESS) { if (lResult != ERROR_SUCCESS) {
RegCloseKey(hKey); RegCloseKey(hKey);
ILFree(pidlMyDocuments); IMalloc_Free(ppM, pidlMyDocuments);
IShellFolder_Release(psfDesktop); IShellFolder_Release(psfDesktop);
return; return;
} }
...@@ -421,7 +425,7 @@ static void test_CallForAttributes(void) ...@@ -421,7 +425,7 @@ static void test_CallForAttributes(void)
ok (lResult == ERROR_SUCCESS, "RegQueryValueEx failed! result: %08lx\n", lResult); ok (lResult == ERROR_SUCCESS, "RegQueryValueEx failed! result: %08lx\n", lResult);
if (lResult != ERROR_SUCCESS) { if (lResult != ERROR_SUCCESS) {
RegCloseKey(hKey); RegCloseKey(hKey);
ILFree(pidlMyDocuments); IMalloc_Free(ppM, pidlMyDocuments);
IShellFolder_Release(psfDesktop); IShellFolder_Release(psfDesktop);
return; return;
} }
...@@ -454,7 +458,7 @@ static void test_CallForAttributes(void) ...@@ -454,7 +458,7 @@ static void test_CallForAttributes(void)
RegSetValueExW(hKey, wszCallForAttributes, 0, REG_DWORD, RegSetValueExW(hKey, wszCallForAttributes, 0, REG_DWORD,
(LPBYTE)&dwOrigCallForAttributes, sizeof(DWORD)); (LPBYTE)&dwOrigCallForAttributes, sizeof(DWORD));
RegCloseKey(hKey); RegCloseKey(hKey);
ILFree(pidlMyDocuments); IMalloc_Free(ppM, pidlMyDocuments);
IShellFolder_Release(psfDesktop); IShellFolder_Release(psfDesktop);
} }
...@@ -518,7 +522,7 @@ static void test_GetAttributesOf(void) ...@@ -518,7 +522,7 @@ static void test_GetAttributesOf(void)
hr = IShellFolder_BindToObject(psfDesktop, pidlMyComputer, NULL, &IID_IShellFolder, (LPVOID*)&psfMyComputer); hr = IShellFolder_BindToObject(psfDesktop, pidlMyComputer, NULL, &IID_IShellFolder, (LPVOID*)&psfMyComputer);
ok (SUCCEEDED(hr), "Desktop failed to bind to MyComputer object! hr = %08lx\n", hr); ok (SUCCEEDED(hr), "Desktop failed to bind to MyComputer object! hr = %08lx\n", hr);
IShellFolder_Release(psfDesktop); IShellFolder_Release(psfDesktop);
ILFree(pidlMyComputer); IMalloc_Free(ppM, pidlMyComputer);
if (FAILED(hr)) return; if (FAILED(hr)) return;
hr = IShellFolder_GetAttributesOf(psfMyComputer, 1, &pidlEmpty, &dwFlags); hr = IShellFolder_GetAttributesOf(psfMyComputer, 1, &pidlEmpty, &dwFlags);
...@@ -573,7 +577,7 @@ static void test_SHGetPathFromIDList(void) ...@@ -573,7 +577,7 @@ static void test_SHGetPathFromIDList(void)
ok (!result, "SHGetPathFromIDList succeeded where it shouldn't!\n"); ok (!result, "SHGetPathFromIDList succeeded where it shouldn't!\n");
ok (GetLastError()==0xdeadbeef, "SHGetPathFromIDList shouldn't set last error! Last error: %08lx\n", GetLastError()); ok (GetLastError()==0xdeadbeef, "SHGetPathFromIDList shouldn't set last error! Last error: %08lx\n", GetLastError());
ILFree(pidlMyComputer); IMalloc_Free(ppM, pidlMyComputer);
} }
static void test_EnumObjects_and_CompareIDs(void) static void test_EnumObjects_and_CompareIDs(void)
...@@ -591,9 +595,6 @@ static void test_EnumObjects_and_CompareIDs(void) ...@@ -591,9 +595,6 @@ static void test_EnumObjects_and_CompareIDs(void)
OleInitialize(NULL); OleInitialize(NULL);
hr = SHGetMalloc(&ppM);
ok(hr == S_OK, "SHGetMalloc failed %08lx\n", hr);
hr = SHGetDesktopFolder(&IDesktopFolder); hr = SHGetDesktopFolder(&IDesktopFolder);
ok(hr == S_OK, "SHGetDesktopfolder failed %08lx\n", hr); ok(hr == S_OK, "SHGetDesktopfolder failed %08lx\n", hr);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment