Commit c9fc3510 authored by Zebediah Figura's avatar Zebediah Figura Committed by Alexandre Julliard

msi: Handle the remote case directly in MsiGetTargetPathA().

parent 2e2934e4
...@@ -271,26 +271,50 @@ static UINT MSI_GetTargetPath( MSIHANDLE hInstall, LPCWSTR szFolder, ...@@ -271,26 +271,50 @@ static UINT MSI_GetTargetPath( MSIHANDLE hInstall, LPCWSTR szFolder,
/*********************************************************************** /***********************************************************************
* MsiGetTargetPathA (MSI.@) * MsiGetTargetPathA (MSI.@)
*/ */
UINT WINAPI MsiGetTargetPathA( MSIHANDLE hInstall, LPCSTR szFolder, UINT WINAPI MsiGetTargetPathA(MSIHANDLE hinst, const char *folder, char *buf, DWORD *sz)
LPSTR szPathBuf, LPDWORD pcchPathBuf )
{ {
LPWSTR szwFolder; MSIPACKAGE *package;
awstring path; const WCHAR *path;
WCHAR *folderW;
UINT r; UINT r;
TRACE("%s %p %p\n", debugstr_a(szFolder), szPathBuf, pcchPathBuf); TRACE("%s %p %p\n", debugstr_a(folder), buf, sz);
szwFolder = strdupAtoW(szFolder); if (!folder)
if (szFolder && !szwFolder) return ERROR_INVALID_PARAMETER;
return ERROR_FUNCTION_FAILED;
if (!(folderW = strdupAtoW(folder)))
return ERROR_OUTOFMEMORY;
package = msihandle2msiinfo(hinst, MSIHANDLETYPE_PACKAGE);
if (!package)
{
WCHAR *path = NULL;
MSIHANDLE remote;
path.unicode = FALSE; if (!(remote = msi_get_remote(hinst)))
path.str.a = szPathBuf; {
heap_free(folderW);
return ERROR_INVALID_HANDLE;
}
r = MSI_GetTargetPath( hInstall, szwFolder, &path, pcchPathBuf ); r = remote_GetTargetPath(remote, folderW, &path);
if (!r)
r = msi_strncpyWtoA(path, -1, buf, sz, TRUE);
msi_free( szwFolder ); midl_user_free(path);
heap_free(folderW);
return r;
}
path = msi_get_target_folder(package, folderW);
if (path)
r = msi_strncpyWtoA(path, -1, buf, sz, FALSE);
else
r = ERROR_DIRECTORY;
heap_free(folderW);
msiobj_release(&package->hdr);
return r; return r;
} }
......
...@@ -485,28 +485,28 @@ static void test_targetpath(MSIHANDLE hinst) ...@@ -485,28 +485,28 @@ static void test_targetpath(MSIHANDLE hinst)
sz = 0; sz = 0;
r = MsiGetTargetPathA(hinst, "TARGETDIR", NULL, &sz); r = MsiGetTargetPathA(hinst, "TARGETDIR", NULL, &sz);
ok(hinst, !r, "got %u\n", r); ok(hinst, !r, "got %u\n", r);
todo_wine_ok(hinst, sz == 6, "got size %u\n", sz); ok(hinst, sz == 6, "got size %u\n", sz);
sz = 0; sz = 0;
strcpy(buffer,"q"); strcpy(buffer,"q");
r = MsiGetTargetPathA(hinst, "TARGETDIR", buffer, &sz); r = MsiGetTargetPathA(hinst, "TARGETDIR", buffer, &sz);
ok(hinst, r == ERROR_MORE_DATA, "got %u\n", r); ok(hinst, r == ERROR_MORE_DATA, "got %u\n", r);
ok(hinst, !strcmp(buffer, "q"), "got \"%s\"\n", buffer); ok(hinst, !strcmp(buffer, "q"), "got \"%s\"\n", buffer);
todo_wine_ok(hinst, sz == 6, "got size %u\n", sz); ok(hinst, sz == 6, "got size %u\n", sz);
sz = 1; sz = 1;
strcpy(buffer,"x"); strcpy(buffer,"x");
r = MsiGetTargetPathA(hinst, "TARGETDIR", buffer, &sz); r = MsiGetTargetPathA(hinst, "TARGETDIR", buffer, &sz);
ok(hinst, r == ERROR_MORE_DATA, "got %u\n", r); ok(hinst, r == ERROR_MORE_DATA, "got %u\n", r);
ok(hinst, !buffer[0], "got \"%s\"\n", buffer); ok(hinst, !buffer[0], "got \"%s\"\n", buffer);
todo_wine_ok(hinst, sz == 6, "got size %u\n", sz); ok(hinst, sz == 6, "got size %u\n", sz);
sz = 3; sz = 3;
strcpy(buffer,"x"); strcpy(buffer,"x");
r = MsiGetTargetPathA(hinst, "TARGETDIR", buffer, &sz); r = MsiGetTargetPathA(hinst, "TARGETDIR", buffer, &sz);
ok(hinst, r == ERROR_MORE_DATA, "got %u\n", r); ok(hinst, r == ERROR_MORE_DATA, "got %u\n", r);
ok(hinst, !strcmp(buffer, "C:"), "got \"%s\"\n", buffer); ok(hinst, !strcmp(buffer, "C:"), "got \"%s\"\n", buffer);
todo_wine_ok(hinst, sz == 6, "got size %u\n", sz); ok(hinst, sz == 6, "got size %u\n", sz);
sz = 4; sz = 4;
strcpy(buffer,"x"); strcpy(buffer,"x");
......
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