Commit 6c6b2a7a authored by Hans Leidekker's avatar Hans Leidekker Committed by Alexandre Julliard

msi: Look at the requested action when publishing assemblies, not the action taken.

parent ff3ed5f0
...@@ -6481,20 +6481,25 @@ static UINT load_assembly(MSIRECORD *rec, LPVOID param) ...@@ -6481,20 +6481,25 @@ static UINT load_assembly(MSIRECORD *rec, LPVOID param)
{ {
ASSEMBLY_LIST *list = param; ASSEMBLY_LIST *list = param;
MSIASSEMBLY *assembly; MSIASSEMBLY *assembly;
LPCWSTR component;
assembly = msi_alloc_zero(sizeof(MSIASSEMBLY)); assembly = msi_alloc_zero(sizeof(MSIASSEMBLY));
if (!assembly) if (!assembly)
return ERROR_OUTOFMEMORY; return ERROR_OUTOFMEMORY;
assembly->component = get_loaded_component(list->package, MSI_RecordGetString(rec, 1)); component = MSI_RecordGetString(rec, 1);
assembly->component = get_loaded_component(list->package, component);
if (!assembly->component)
return ERROR_SUCCESS;
if (!assembly->component || !assembly->component->Enabled || if (assembly->component->ActionRequest != INSTALLSTATE_LOCAL &&
!(assembly->component->Action & (INSTALLSTATE_LOCAL | INSTALLSTATE_SOURCE))) assembly->component->ActionRequest != INSTALLSTATE_SOURCE)
{ {
TRACE("Component not set for install, not publishing assembly\n"); TRACE("Component not scheduled for installation: %s\n", debugstr_w(component));
msi_free(assembly); assembly->component->Action = assembly->component->Installed;
return ERROR_SUCCESS; return ERROR_SUCCESS;
} }
assembly->component->Action = assembly->component->ActionRequest;
assembly->feature = find_feature_by_name(list->package, MSI_RecordGetString(rec, 2)); assembly->feature = find_feature_by_name(list->package, MSI_RecordGetString(rec, 2));
assembly->file = msi_find_file(list->package, assembly->component->KeyPath); assembly->file = msi_find_file(list->package, assembly->component->KeyPath);
......
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