shell32: IKnownFolder::SetPath modified to use redirection instead of overwriting original path.
This commit is contained in:
parent
823560d472
commit
e1dc5447e8
|
@ -3459,8 +3459,6 @@ static HRESULT WINAPI knownfolder_SetPath(
|
||||||
{
|
{
|
||||||
struct knownfolder *knownfolder = impl_from_IKnownFolder( iface );
|
struct knownfolder *knownfolder = impl_from_IKnownFolder( iface );
|
||||||
HRESULT hr = S_OK;
|
HRESULT hr = S_OK;
|
||||||
HKEY hKey;
|
|
||||||
WCHAR szPath[MAX_PATH];
|
|
||||||
|
|
||||||
TRACE("(%p, 0x%08x, %p)\n", knownfolder, dwFlags, debugstr_w(pszPath));
|
TRACE("(%p, 0x%08x, %p)\n", knownfolder, dwFlags, debugstr_w(pszPath));
|
||||||
|
|
||||||
|
@ -3469,22 +3467,7 @@ static HRESULT WINAPI knownfolder_SetPath(
|
||||||
hr = E_FAIL;
|
hr = E_FAIL;
|
||||||
|
|
||||||
if(SUCCEEDED(hr))
|
if(SUCCEEDED(hr))
|
||||||
{
|
hr = redirect_known_folder(&knownfolder->id, NULL, 0, pszPath, 0, NULL, NULL);
|
||||||
if(dwFlags & KF_FLAG_DONT_UNEXPAND)
|
|
||||||
lstrcpyW(szPath, pszPath);
|
|
||||||
else
|
|
||||||
hr = ( ExpandEnvironmentStringsW(pszPath, szPath, sizeof(szPath)/sizeof(szPath[0]))!=0 ? S_OK : HRESULT_FROM_WIN32(GetLastError()));
|
|
||||||
}
|
|
||||||
|
|
||||||
if(SUCCEEDED(hr))
|
|
||||||
hr = HRESULT_FROM_WIN32(RegOpenKeyExW(HKEY_LOCAL_MACHINE, knownfolder->registryPath, 0, KEY_SET_VALUE, &hKey));
|
|
||||||
|
|
||||||
if(SUCCEEDED(hr))
|
|
||||||
{
|
|
||||||
hr = HRESULT_FROM_WIN32(RegSetValueExW(hKey, szRelativePath, 0, REG_SZ, (LPBYTE)pszPath, (lstrlenW(pszPath)+1)*sizeof(WCHAR)));
|
|
||||||
|
|
||||||
RegCloseKey(hKey);
|
|
||||||
}
|
|
||||||
|
|
||||||
return hr;
|
return hr;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1256,7 +1256,6 @@ static void test_knownFolders(void)
|
||||||
/* verify */
|
/* verify */
|
||||||
hr = IKnownFolder_GetPath(folder, 0, &folderPath);
|
hr = IKnownFolder_GetPath(folder, 0, &folderPath);
|
||||||
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
||||||
todo_wine
|
|
||||||
ok(lstrcmpiW(folderPath, sExamplePath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sExamplePath));
|
ok(lstrcmpiW(folderPath, sExamplePath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sExamplePath));
|
||||||
CoTaskMemFree(folderPath);
|
CoTaskMemFree(folderPath);
|
||||||
|
|
||||||
|
@ -1292,14 +1291,12 @@ static void test_knownFolders(void)
|
||||||
/* verify */
|
/* verify */
|
||||||
hr = IKnownFolder_GetPath(folder, 0, &folderPath);
|
hr = IKnownFolder_GetPath(folder, 0, &folderPath);
|
||||||
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
||||||
todo_wine
|
|
||||||
ok(lstrcmpiW(folderPath, sExamplePath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sExamplePath));
|
ok(lstrcmpiW(folderPath, sExamplePath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sExamplePath));
|
||||||
CoTaskMemFree(folderPath);
|
CoTaskMemFree(folderPath);
|
||||||
|
|
||||||
/* verify sub folder */
|
/* verify sub folder */
|
||||||
hr = IKnownFolder_GetPath(subFolder, 0, &folderPath);
|
hr = IKnownFolder_GetPath(subFolder, 0, &folderPath);
|
||||||
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
||||||
todo_wine
|
|
||||||
ok(lstrcmpiW(folderPath, sSubFolderPath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sSubFolderPath));
|
ok(lstrcmpiW(folderPath, sSubFolderPath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sSubFolderPath));
|
||||||
CoTaskMemFree(folderPath);
|
CoTaskMemFree(folderPath);
|
||||||
|
|
||||||
|
@ -1335,14 +1332,12 @@ static void test_knownFolders(void)
|
||||||
/* verify */
|
/* verify */
|
||||||
hr = IKnownFolder_GetPath(folder, 0, &folderPath);
|
hr = IKnownFolder_GetPath(folder, 0, &folderPath);
|
||||||
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
||||||
todo_wine
|
|
||||||
ok(lstrcmpiW(folderPath, sExamplePath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sExamplePath));
|
ok(lstrcmpiW(folderPath, sExamplePath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sExamplePath));
|
||||||
CoTaskMemFree(folderPath);
|
CoTaskMemFree(folderPath);
|
||||||
|
|
||||||
/* verify sub folder */
|
/* verify sub folder */
|
||||||
hr = IKnownFolder_GetPath(subFolder, 0, &folderPath);
|
hr = IKnownFolder_GetPath(subFolder, 0, &folderPath);
|
||||||
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
||||||
todo_wine
|
|
||||||
ok(lstrcmpiW(folderPath, sSubFolderPath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sSubFolderPath));
|
ok(lstrcmpiW(folderPath, sSubFolderPath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sSubFolderPath));
|
||||||
CoTaskMemFree(folderPath);
|
CoTaskMemFree(folderPath);
|
||||||
|
|
||||||
|
@ -1374,14 +1369,12 @@ static void test_knownFolders(void)
|
||||||
/* verify */
|
/* verify */
|
||||||
hr = IKnownFolder_GetPath(folder, 0, &folderPath);
|
hr = IKnownFolder_GetPath(folder, 0, &folderPath);
|
||||||
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
||||||
todo_wine
|
|
||||||
ok(lstrcmpiW(folderPath, sExamplePath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sExamplePath));
|
ok(lstrcmpiW(folderPath, sExamplePath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sExamplePath));
|
||||||
CoTaskMemFree(folderPath);
|
CoTaskMemFree(folderPath);
|
||||||
|
|
||||||
/* verify sub folder */
|
/* verify sub folder */
|
||||||
hr = IKnownFolder_GetPath(subFolder, 0, &folderPath);
|
hr = IKnownFolder_GetPath(subFolder, 0, &folderPath);
|
||||||
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
ok(hr == S_OK, "failed to get known folder path: 0x%08x\n", hr);
|
||||||
todo_wine
|
|
||||||
ok(lstrcmpiW(folderPath, sSubFolderPath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sSubFolderPath));
|
ok(lstrcmpiW(folderPath, sSubFolderPath)==0, "invalid known folder path retrieved: \"%s\" when \"%s\" was expected\n", wine_dbgstr_w(folderPath), wine_dbgstr_w(sSubFolderPath));
|
||||||
CoTaskMemFree(folderPath);
|
CoTaskMemFree(folderPath);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue