msi: Store the base URL of the MSI package if it is downloaded.

This commit is contained in:
James Hawkins 2006-11-07 15:13:47 -08:00 committed by Alexandre Julliard
parent 542101fcda
commit ae18c2dc7f
5 changed files with 19 additions and 5 deletions

View File

@ -532,7 +532,7 @@ static UINT ready_media_for_file( MSIPACKAGE *package, struct media_info *mi,
/* only download the remote cabinet file if a local copy does not exist */ /* only download the remote cabinet file if a local copy does not exist */
if (GetFileAttributesW(mi->source) == INVALID_FILE_ATTRIBUTES && if (GetFileAttributesW(mi->source) == INVALID_FILE_ATTRIBUTES &&
UrlIsW(package->PackagePath, URLIS_URL)) UrlIsW(package->BaseURL, URLIS_URL))
{ {
rc = msi_extract_remote_cabinet(package, mi); rc = msi_extract_remote_cabinet(package, mi);
} }

View File

@ -591,6 +591,7 @@ void ACTION_free_package_structures( MSIPACKAGE* package)
msi_free(package->script); msi_free(package->script);
} }
msi_free(package->BaseURL);
msi_free(package->PackagePath); msi_free(package->PackagePath);
msi_free(package->ProductCode); msi_free(package->ProductCode);
msi_free(package->ActionFormat); msi_free(package->ActionFormat);

View File

@ -228,6 +228,7 @@ typedef struct tagMSIPACKAGE
struct list RunningActions; struct list RunningActions;
LPWSTR BaseURL;
LPWSTR PackagePath; LPWSTR PackagePath;
LPWSTR ProductCode; LPWSTR ProductCode;
@ -620,7 +621,7 @@ extern UINT VIEW_find_column( MSIVIEW *, LPCWSTR, UINT * );
extern UINT MSI_SetInstallLevel( MSIPACKAGE *package, int iInstallLevel ); extern UINT MSI_SetInstallLevel( MSIPACKAGE *package, int iInstallLevel );
/* package internals */ /* package internals */
extern MSIPACKAGE *MSI_CreatePackage( MSIDATABASE * ); extern MSIPACKAGE *MSI_CreatePackage( MSIDATABASE *, LPWSTR );
extern UINT MSI_OpenPackageW( LPCWSTR szPackage, MSIPACKAGE ** ); extern UINT MSI_OpenPackageW( LPCWSTR szPackage, MSIPACKAGE ** );
extern UINT MSI_SetTargetPathW( MSIPACKAGE *, LPCWSTR, LPCWSTR ); extern UINT MSI_SetTargetPathW( MSIPACKAGE *, LPCWSTR, LPCWSTR );
extern UINT MSI_SetPropertyW( MSIPACKAGE *, LPCWSTR, LPCWSTR ); extern UINT MSI_SetPropertyW( MSIPACKAGE *, LPCWSTR, LPCWSTR );

View File

@ -428,7 +428,7 @@ static UINT msi_get_word_count( MSIPACKAGE *package )
return word_count; return word_count;
} }
MSIPACKAGE *MSI_CreatePackage( MSIDATABASE *db ) MSIPACKAGE *MSI_CreatePackage( MSIDATABASE *db, LPWSTR base_url )
{ {
static const WCHAR szLevel[] = { 'U','I','L','e','v','e','l',0 }; static const WCHAR szLevel[] = { 'U','I','L','e','v','e','l',0 };
static const WCHAR szpi[] = {'%','i',0}; static const WCHAR szpi[] = {'%','i',0};
@ -466,6 +466,7 @@ MSIPACKAGE *MSI_CreatePackage( MSIDATABASE *db )
package->WordCount = msi_get_word_count( package ); package->WordCount = msi_get_word_count( package );
package->PackagePath = strdupW( db->path ); package->PackagePath = strdupW( db->path );
package->BaseURL = strdupW( base_url );
/* OK, here is where we do a slew of things to the database to /* OK, here is where we do a slew of things to the database to
* prep for all that is to come as a package */ * prep for all that is to come as a package */
@ -550,6 +551,7 @@ UINT MSI_OpenPackageW(LPCWSTR szPackage, MSIPACKAGE **pPackage)
MSIDATABASE *db = NULL; MSIDATABASE *db = NULL;
MSIPACKAGE *package; MSIPACKAGE *package;
MSIHANDLE handle; MSIHANDLE handle;
LPWSTR ptr, base_url = NULL;
UINT r; UINT r;
static const WCHAR OriginalDatabase[] = static const WCHAR OriginalDatabase[] =
@ -571,7 +573,16 @@ UINT MSI_OpenPackageW(LPCWSTR szPackage, MSIPACKAGE **pPackage)
LPCWSTR file; LPCWSTR file;
if ( UrlIsW( szPackage, URLIS_URL ) ) if ( UrlIsW( szPackage, URLIS_URL ) )
{
file = msi_download_file( szPackage, temppath ); file = msi_download_file( szPackage, temppath );
base_url = strdupW( szPackage );
if ( !base_url )
return ERROR_OUTOFMEMORY;
ptr = strrchrW( base_url, '/' );
if (ptr) *(ptr + 1) = '\0';
}
else else
file = copy_package_to_temp( szPackage, temppath ); file = copy_package_to_temp( szPackage, temppath );
@ -589,7 +600,8 @@ UINT MSI_OpenPackageW(LPCWSTR szPackage, MSIPACKAGE **pPackage)
} }
} }
package = MSI_CreatePackage( db ); package = MSI_CreatePackage( db, base_url );
msi_free( base_url );
msiobj_release( &db->hdr ); msiobj_release( &db->hdr );
if( !package ) if( !package )
return ERROR_FUNCTION_FAILED; return ERROR_FUNCTION_FAILED;

View File

@ -43,7 +43,7 @@ MSIPREVIEW *MSI_EnableUIPreview( MSIDATABASE *db )
MSIPREVIEW *preview = NULL; MSIPREVIEW *preview = NULL;
MSIPACKAGE *package; MSIPACKAGE *package;
package = MSI_CreatePackage( db ); package = MSI_CreatePackage( db, NULL );
if( package ) if( package )
{ {
preview = alloc_msiobject( MSIHANDLETYPE_PREVIEW, sizeof (MSIPREVIEW), preview = alloc_msiobject( MSIHANDLETYPE_PREVIEW, sizeof (MSIPREVIEW),