Fixed mapping of file extensions to text.
diff --git a/dlls/shell32/classes.c b/dlls/shell32/classes.c
index bcb321a..b656b5c 100644
--- a/dlls/shell32/classes.c
+++ b/dlls/shell32/classes.c
@@ -12,19 +12,23 @@
#include "shlobj.h"
#include "shell32_main.h"
+#include "shlguid.h"
+#include "shresdef.h"
DEFAULT_DEBUG_CHANNEL(shell)
#define MAX_EXTENSION_LENGTH 20
-BOOL HCR_MapTypeToValue ( LPCSTR szExtension, LPSTR szFileType, DWORD len)
+BOOL HCR_MapTypeToValue ( LPCSTR szExtension, LPSTR szFileType, DWORD len, BOOL bPrependDot)
{ HKEY hkey;
char szTemp[MAX_EXTENSION_LENGTH + 2];
TRACE("%s %p\n",szExtension, szFileType );
- strcpy(szTemp, ".");
- strncat(szTemp, szExtension, MAX_EXTENSION_LENGTH);
+ if (bPrependDot)
+ strcpy(szTemp, ".");
+
+ lstrcpynA(szTemp+((bPrependDot)?1:0), szExtension, MAX_EXTENSION_LENGTH);
if (RegOpenKeyExA(HKEY_CLASSES_ROOT,szTemp,0,0x02000000,&hkey))
{ return FALSE;
@@ -108,26 +112,40 @@
BOOL HCR_GetClassName (REFIID riid, LPSTR szDest, DWORD len)
{ HKEY hkey;
char xriid[50];
+ BOOL ret = FALSE;
+ DWORD buflen = len;
strcpy(xriid,"CLSID\\");
WINE_StringFromCLSID(riid,&xriid[strlen(xriid)]);
TRACE("%s\n",xriid );
- if (RegOpenKeyExA(HKEY_CLASSES_ROOT,xriid,0,KEY_READ,&hkey))
- { return FALSE;
+ if (!RegOpenKeyExA(HKEY_CLASSES_ROOT,xriid,0,KEY_READ,&hkey))
+ {
+ if (!RegQueryValueExA(hkey,"",0,NULL,szDest,&len))
+ {
+ ret = TRUE;
+ }
+ RegCloseKey(hkey);
}
- if (RegQueryValueExA(hkey,"",0,NULL,szDest,&len))
- { RegCloseKey(hkey);
- return FALSE;
- }
-
- RegCloseKey(hkey);
+ if (!ret || !szDest[0])
+ {
+ if(IsEqualIID(riid, &CLSID_ShellDesktop))
+ {
+ LoadStringA(shell32_hInstance, IDS_DESKTOP, szDest, buflen);
+ ret = TRUE;
+ }
+ else if (IsEqualIID(riid, &IID_MyComputer))
+ {
+ LoadStringA(shell32_hInstance, IDS_MYCOMPUTER, szDest, buflen);
+ ret = TRUE;
+ }
+ }
TRACE("-- %s\n", szDest);
- return TRUE;
+ return ret;
}
/***************************************************************************************
@@ -156,7 +174,7 @@
{
RegCloseKey(hkey);
return FALSE;
- }
+ }
RegCloseKey(hkey);