fusion: Use parsed properties for assembly enumeration instead of trying to parse the display name again.

The display name passed in may not be normalized, e.g. if the version number
is passed as "1.0.0.00000" instead of "1.0.0.0". This patch should also cut
down on case insensitive file searches.
This commit is contained in:
Hans Leidekker 2009-02-19 14:05:54 +01:00 committed by Alexandre Julliard
parent 43094e4a3e
commit 0aa3c187d8
2 changed files with 53 additions and 28 deletions

View File

@ -162,17 +162,19 @@ static const IAssemblyEnumVtbl AssemblyEnumVtbl = {
static void parse_name(IAssemblyName *name, int depth, LPWSTR path, LPWSTR buf) static void parse_name(IAssemblyName *name, int depth, LPWSTR path, LPWSTR buf)
{ {
WCHAR disp[MAX_PATH]; WCHAR disp[MAX_PATH];
LPWSTR ptr, end;
LPCWSTR verptr, pubkeyptr; LPCWSTR verptr, pubkeyptr;
HRESULT hr; HRESULT hr;
DWORD size; DWORD size, major_size, minor_size, build_size, revision_size;
WORD major, minor, build, revision;
static const WCHAR star[] = {'*',0}; static const WCHAR star[] = {'*',0};
static const WCHAR ss_fmt[] = {'%','s','\\','%','s',0}; static const WCHAR ss_fmt[] = {'%','s','\\','%','s',0};
static const WCHAR verpubkey[] = {'%','s','\\','%','s','_','_','%','s',0}; static const WCHAR verpubkey[] = {'%','s','\\','%','s','_','_','%','s',0};
static const WCHAR version[] = {'V','e','r','s','i','o','n','=',0}; static const WCHAR ver_fmt[] = {'%','u','.','%','u','.','%','u','.','%','u',0};
static const WCHAR pubkeytok[] = {
'P','u','b','l','i','c','K','e','y','T','o','k','e','n','=',0}; WCHAR version[24]; /* strlen("65535") * 4 + 3 + 1 */
WCHAR token_str[TOKEN_LENGTH + 1];
BYTE token[BYTES_PER_TOKEN];
if (depth == 0) if (depth == 0)
{ {
@ -186,36 +188,33 @@ static void parse_name(IAssemblyName *name, int depth, LPWSTR path, LPWSTR buf)
} }
else if (depth == 1) else if (depth == 1)
{ {
size = MAX_PATH; major_size = sizeof(major);
hr = IAssemblyName_GetDisplayName(name, disp, &size, 0); IAssemblyName_GetProperty(name, ASM_NAME_MAJOR_VERSION, &major, &major_size);
if (FAILED(hr))
{
sprintfW(buf, verpubkey, path, star, star);
return;
}
ptr = disp; minor_size = sizeof(minor);
verptr = strstrW(ptr, version); IAssemblyName_GetProperty(name, ASM_NAME_MINOR_VERSION, &minor, &minor_size);
if (!verptr)
verptr = star; build_size = sizeof(build);
IAssemblyName_GetProperty(name, ASM_NAME_BUILD_NUMBER, &build, &build_size);
revision_size = sizeof(revision);
IAssemblyName_GetProperty(name, ASM_NAME_REVISION_NUMBER, &revision, &revision_size);
if (!major_size || !minor_size || !build_size || !revision_size) verptr = star;
else else
{ {
verptr = strchrW(verptr, '=') + 1; sprintfW(version, ver_fmt, major, minor, build, revision);
if ((end = strchrW(verptr, ','))) verptr = version;
{
*end = '\0';
ptr = end + 1;
}
} }
pubkeyptr = strstrW(ptr, pubkeytok); size = sizeof(token);
if (!pubkeyptr) IAssemblyName_GetProperty(name, ASM_NAME_PUBLIC_KEY_TOKEN, token, &size);
pubkeyptr = star;
if (!size) pubkeyptr = star;
else else
{ {
pubkeyptr = strchrW(pubkeyptr, '=') + 1; token_to_str(token, token_str);
if ((end = strchrW(pubkeyptr, ','))) pubkeyptr = token_str;
*end = '\0';
} }
sprintfW(buf, verpubkey, path, verptr, pubkeyptr); sprintfW(buf, verpubkey, path, verptr, pubkeyptr);

View File

@ -989,6 +989,8 @@ static void test_QueryAssemblyInfo(void)
static const WCHAR wine[] = {'w','i','n','e',0}; static const WCHAR wine[] = {'w','i','n','e',0};
static const WCHAR ver[] = { static const WCHAR ver[] = {
'V','e','r','s','i','o','n','=','1','.','0','.','0','.','0',0}; 'V','e','r','s','i','o','n','=','1','.','0','.','0','.','0',0};
static const WCHAR otherver[] = {
'V','e','r','s','i','o','n','=','1','.','0','.','0','.','0','0','0','0','0',0};
static const WCHAR badver[] = { static const WCHAR badver[] = {
'V','e','r','s','i','o','n','=','1','.','0','.','0','.','1',0}; 'V','e','r','s','i','o','n','=','1','.','0','.','0','.','1',0};
static const WCHAR culture[] = { static const WCHAR culture[] = {
@ -1303,6 +1305,30 @@ static void test_QueryAssemblyInfo(void)
"Expected %d, got %d\n", lstrlenW(asmpath) + 1, info.cchBuf); "Expected %d, got %d\n", lstrlenW(asmpath) + 1, info.cchBuf);
} }
/* display name is "wine, Version=1.0.0.00000" */
INIT_ASM_INFO();
lstrcpyW(name, wine);
lstrcatW(name, commasep);
lstrcatW(name, otherver);
hr = IAssemblyCache_QueryAssemblyInfo(cache, QUERYASMINFO_FLAG_GETSIZE,
name, &info);
ok(hr == S_OK, "Expected S_OK, got %08x\n", hr);
ok(info.cbAssemblyInfo == sizeof(ASSEMBLY_INFO),
"Expected sizeof(ASSEMBLY_INFO), got %d\n", info.cbAssemblyInfo);
ok(info.dwAssemblyFlags == ASSEMBLYINFO_FLAG_INSTALLED,
"Expected ASSEMBLYINFO_FLAG_INSTALLED, got %08x\n", info.dwAssemblyFlags);
ok(info.uliAssemblySizeInKB.u.HighPart == 0,
"Expected 0, got %d\n", info.uliAssemblySizeInKB.u.HighPart);
todo_wine
{
ok(info.uliAssemblySizeInKB.u.LowPart == 4,
"Expected 4, got %d\n", info.uliAssemblySizeInKB.u.LowPart);
ok(!lstrcmpW(info.pszCurrentAssemblyPathBuf, asmpath),
"Wrong assembly path returned\n");
ok(info.cchBuf == lstrlenW(asmpath) + 1,
"Expected %d, got %d\n", lstrlenW(asmpath) + 1, info.cchBuf);
}
/* display name is "wine, Version=1.0.0.1", versions don't match */ /* display name is "wine, Version=1.0.0.1", versions don't match */
INIT_ASM_INFO(); INIT_ASM_INFO();
lstrcpyW(name, wine); lstrcpyW(name, wine);