Commit 6607180f authored by Mike McCormack's avatar Mike McCormack Committed by Alexandre Julliard

msi: Simplify create_component_advertise_string() a little.

parent 50a9c208
...@@ -869,49 +869,35 @@ void reduce_to_shortfilename(WCHAR* filename) ...@@ -869,49 +869,35 @@ void reduce_to_shortfilename(WCHAR* filename)
LPWSTR create_component_advertise_string(MSIPACKAGE* package, LPWSTR create_component_advertise_string(MSIPACKAGE* package,
MSICOMPONENT* component, LPCWSTR feature) MSICOMPONENT* component, LPCWSTR feature)
{ {
GUID clsid; static const WCHAR fmt[] = {'%','s','%','s','%','c','%','s',0};
WCHAR productid_85[21]; WCHAR productid_85[21], component_85[21];
WCHAR component_85[21];
/*
* I have a fair bit of confusion as to when a < is used and when a > is
* used. I do not think i have it right...
*
* Ok it appears that the > is used if there is a guid for the compoenent
* and the < is used if not.
*/
static const WCHAR fmt1[] = {'%','s','%','s','<',0,0};
static const WCHAR fmt2[] = {'%','s','%','s','>','%','s',0,0};
LPWSTR output = NULL; LPWSTR output = NULL;
DWORD sz = 0; DWORD sz = 0;
GUID clsid;
memset(productid_85,0,sizeof(productid_85)); /* > is used if there is a component GUID and < if not. */
memset(component_85,0,sizeof(component_85));
CLSIDFromString(package->ProductCode, &clsid); productid_85[0] = 0;
component_85[0] = 0;
encode_base85_guid(&clsid,productid_85); CLSIDFromString(package->ProductCode, &clsid);
encode_base85_guid(&clsid, productid_85);
if (component)
{
CLSIDFromString(component->ComponentId, &clsid); CLSIDFromString(component->ComponentId, &clsid);
encode_base85_guid(&clsid,component_85); encode_base85_guid(&clsid, component_85);
}
TRACE("Doing something with this... %s %s %s\n",
debugstr_w(productid_85), debugstr_w(feature),
debugstr_w(component_85));
sz = lstrlenW(productid_85) + lstrlenW(feature); TRACE("prod=%s feat=%s comp=%s\n", debugstr_w(productid_85),
if (component) debugstr_w(feature), debugstr_w(component_85));
sz += lstrlenW(component_85);
sz+=3; sz = 20 + lstrlenW(feature) + 20 + 3;
sz *= sizeof(WCHAR);
output = msi_alloc(sz); output = msi_alloc_zero(sz*sizeof(WCHAR));
memset(output,0,sz);
if (component) sprintfW(output, fmt, productid_85, feature,
sprintfW(output,fmt2,productid_85,feature,component_85); component?'>':'<', component_85);
else
sprintfW(output,fmt1,productid_85,feature);
return output; return output;
} }
......
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