msi [5/13]: Handle remote calls to MsiGetSourcePath

James Hawkins truiken at gmail.com
Tue Jul 3 21:16:15 CDT 2007


Hi,

Changelog:
* Handle remote calls to MsiGetSourcePath.

 dlls/msi/install.c     |   50 +++++++++++++++++++++++++++++++++++++++++++++---
 dlls/msi/msiserver.idl |    1 +
 dlls/msi/package.c     |    8 ++++++++
 3 files changed, 56 insertions(+), 3 deletions(-)

-- 
James Hawkins
-------------- next part --------------
diff --git a/dlls/msi/install.c b/dlls/msi/install.c
index 730c30a..b4f365e 100644
--- a/dlls/msi/install.c
+++ b/dlls/msi/install.c
@@ -314,16 +314,60 @@ static UINT MSI_GetSourcePath( MSIHANDLE
 {
     MSIPACKAGE *package;
     LPWSTR path;
-    UINT r;
+    UINT r = ERROR_FUNCTION_FAILED;
 
     TRACE("%s %p %p\n", debugstr_w(szFolder), szPathBuf, pcchPathBuf );
 
     if (!szFolder)
         return ERROR_INVALID_PARAMETER;
 
-    package = msihandle2msiinfo(hInstall, MSIHANDLETYPE_PACKAGE);
+    package = msihandle2msiinfo( hInstall, MSIHANDLETYPE_PACKAGE );
     if (!package)
-        return ERROR_INVALID_HANDLE;
+    {
+        HRESULT hr;
+        IWineMsiRemotePackage *remote_package;
+        LPWSTR value = NULL;
+        DWORD len;
+
+        remote_package = (IWineMsiRemotePackage *)msi_get_remote( hInstall );
+        if (!remote_package)
+            return ERROR_INVALID_HANDLE;
+
+        len = 0;
+        hr = IWineMsiRemotePackage_GetSourcePath( remote_package, (BSTR *)szFolder,
+                                                  NULL, &len );
+        if (FAILED(hr))
+            goto done;
+
+        len++;
+        value = msi_alloc(len * sizeof(WCHAR));
+        if (!value)
+        {
+            r = ERROR_OUTOFMEMORY;
+            goto done;
+        }
+
+        hr = IWineMsiRemotePackage_GetSourcePath( remote_package, (BSTR *)szFolder,
+                                                  (BSTR *)value, &len);
+        if (FAILED(hr))
+            goto done;
+
+        r = msi_strcpy_to_awstring( value, szPathBuf, pcchPathBuf );
+
+done:
+        IWineMsiRemotePackage_Release( remote_package );
+        msi_free( value );
+
+        if (FAILED(hr))
+        {
+            if (HRESULT_FACILITY(hr) == FACILITY_WIN32)
+                return HRESULT_CODE(hr);
+
+            return ERROR_FUNCTION_FAILED;
+        }
+
+        return r;
+    }
 
     if (szPathBuf->str.w && !pcchPathBuf )
     {
diff --git a/dlls/msi/msiserver.idl b/dlls/msi/msiserver.idl
index 187e66b..53dd622 100644
--- a/dlls/msi/msiserver.idl
+++ b/dlls/msi/msiserver.idl
@@ -43,6 +43,7 @@ interface IWineMsiRemotePackage : IUnkno
     HRESULT DoAction( [in] BSTR *action );
     HRESULT Sequence( [in] BSTR *table, [in] int sequence );
     HRESULT GetTargetPath( [in] BSTR *folder, [out] BSTR *value, [out] DWORD *size );
+    HRESULT GetSourcePath( [in] BSTR *folder, [out] BSTR *value, [out] DWORD *size );
 }
 
 [
diff --git a/dlls/msi/package.c b/dlls/msi/package.c
index 8dd40ce..1b83e56 100644
--- a/dlls/msi/package.c
+++ b/dlls/msi/package.c
@@ -1597,6 +1597,13 @@ HRESULT WINAPI mrp_GetTargetPath( IWineM
     return HRESULT_FROM_WIN32(r);
 }
 
+HRESULT WINAPI mrp_GetSourcePath( IWineMsiRemotePackage *iface, BSTR *folder, BSTR *value, DWORD *size )
+{
+    msi_remote_package_impl* This = mrp_from_IWineMsiRemotePackage( iface );
+    UINT r = MsiGetSourcePathW(This->package, (LPWSTR)folder, (LPWSTR)value, size);
+    return HRESULT_FROM_WIN32(r);
+}
+
 static const IWineMsiRemotePackageVtbl msi_remote_package_vtbl =
 {
     mrp_QueryInterface,
@@ -1610,6 +1617,7 @@ static const IWineMsiRemotePackageVtbl m
     mrp_DoAction,
     mrp_Sequence,
     mrp_GetTargetPath,
+    mrp_GetSourcePath,
 };
 
 HRESULT create_msi_remote_package( IUnknown *pOuter, LPVOID *ppObj )
-- 
1.4.1


More information about the wine-patches mailing list