Commit c62f428d authored by Francois Gouget's avatar Francois Gouget Committed by Alexandre Julliard

shdocvw: Set the CLSID_Internet shell folder's attributes.

parent d7371fc4
...@@ -64,8 +64,17 @@ struct regsvr_coclass ...@@ -64,8 +64,17 @@ struct regsvr_coclass
LPCSTR progid; /* can be NULL to omit */ LPCSTR progid; /* can be NULL to omit */
LPCSTR viprogid; /* can be NULL to omit */ LPCSTR viprogid; /* can be NULL to omit */
LPCSTR progid_extra; /* can be NULL to omit */ LPCSTR progid_extra; /* can be NULL to omit */
DWORD flags;
DWORD dwAttributes;
DWORD dwCallForAttributes;
}; };
/* flags for regsvr_coclass.flags */
#define SHELLEX_MAYCHANGEDEFAULTMENU 0x00000001
#define SHELLFOLDER_WANTSFORPARSING 0x00000002
#define SHELLFOLDER_ATTRIBUTES 0x00000004
#define SHELLFOLDER_CALLFORATTRIBUTES 0x00000008
static HRESULT register_coclasses(struct regsvr_coclass const *list); static HRESULT register_coclasses(struct regsvr_coclass const *list);
static HRESULT unregister_coclasses(struct regsvr_coclass const *list); static HRESULT unregister_coclasses(struct regsvr_coclass const *list);
...@@ -101,7 +110,17 @@ static WCHAR const viprogid_keyname[25] = { ...@@ -101,7 +110,17 @@ static WCHAR const viprogid_keyname[25] = {
'V', 'e', 'r', 's', 'i', 'o', 'n', 'I', 'n', 'd', 'e', 'p', 'V', 'e', 'r', 's', 'i', 'o', 'n', 'I', 'n', 'd', 'e', 'p',
'e', 'n', 'd', 'e', 'n', 't', 'P', 'r', 'o', 'g', 'I', 'D', 'e', 'n', 'd', 'e', 'n', 't', 'P', 'r', 'o', 'g', 'I', 'D',
0 }; 0 };
static WCHAR const shellex_keyname[8] = {
's', 'h', 'e', 'l', 'l', 'e', 'x', 0 };
static WCHAR const shellfolder_keyname[12] = {
'S', 'h', 'e', 'l', 'l', 'F', 'o', 'l', 'd', 'e', 'r', 0 };
static WCHAR const mcdm_keyname[21] = {
'M', 'a', 'y', 'C', 'h', 'a', 'n', 'g', 'e', 'D', 'e', 'f',
'a', 'u', 'l', 't', 'M', 'e', 'n', 'u', 0 };
static char const tmodel_valuename[] = "ThreadingModel"; static char const tmodel_valuename[] = "ThreadingModel";
static char const wfparsing_valuename[] = "WantsFORPARSING";
static char const attributes_valuename[] = "Attributes";
static char const cfattributes_valuename[] = "CallForAttributes";
static WCHAR const lcs32_keyname[] = { static WCHAR const lcs32_keyname[] = {
'L','o','c','a','l','S','e','r','v','e','r','3','2',0 }; 'L','o','c','a','l','S','e','r','v','e','r','3','2',0 };
static const WCHAR szIERelPath[] = { static const WCHAR szIERelPath[] = {
...@@ -270,6 +289,42 @@ static HRESULT register_coclasses(struct regsvr_coclass const *list) ...@@ -270,6 +289,42 @@ static HRESULT register_coclasses(struct regsvr_coclass const *list)
if (res != ERROR_SUCCESS) goto error_close_clsid_key; if (res != ERROR_SUCCESS) goto error_close_clsid_key;
} }
if (list->flags & SHELLEX_MAYCHANGEDEFAULTMENU) {
HKEY shellex_key, mcdm_key;
res = RegCreateKeyExW(clsid_key, shellex_keyname, 0, NULL, 0,
KEY_READ | KEY_WRITE, NULL,
&shellex_key, NULL);
if (res != ERROR_SUCCESS) goto error_close_clsid_key;
res = RegCreateKeyExW(shellex_key, mcdm_keyname, 0, NULL, 0,
KEY_READ | KEY_WRITE, NULL,
&mcdm_key, NULL);
RegCloseKey(shellex_key);
if (res != ERROR_SUCCESS) goto error_close_clsid_key;
RegCloseKey(mcdm_key);
}
if (list->flags &
(SHELLFOLDER_WANTSFORPARSING|SHELLFOLDER_ATTRIBUTES|SHELLFOLDER_CALLFORATTRIBUTES))
{
HKEY shellfolder_key;
res = RegCreateKeyExW(clsid_key, shellfolder_keyname, 0, NULL, 0,
KEY_READ | KEY_WRITE, NULL,
&shellfolder_key, NULL);
if (res != ERROR_SUCCESS) goto error_close_clsid_key;
if (list->flags & SHELLFOLDER_WANTSFORPARSING)
res = RegSetValueExA(shellfolder_key, wfparsing_valuename, 0, REG_SZ, (LPBYTE)"", 1);
if (list->flags & SHELLFOLDER_ATTRIBUTES)
res = RegSetValueExA(shellfolder_key, attributes_valuename, 0, REG_DWORD,
(LPBYTE)&list->dwAttributes, sizeof(DWORD));
if (list->flags & SHELLFOLDER_CALLFORATTRIBUTES)
res = RegSetValueExA(shellfolder_key, cfattributes_valuename, 0, REG_DWORD,
(LPBYTE)&list->dwCallForAttributes, sizeof(DWORD));
RegCloseKey(shellfolder_key);
if (res != ERROR_SUCCESS) goto error_close_clsid_key;
}
if (list->progid) { if (list->progid) {
res = register_key_defvalueA(clsid_key, progid_keyname, res = register_key_defvalueA(clsid_key, progid_keyname,
list->progid); list->progid);
...@@ -618,7 +673,10 @@ static struct regsvr_coclass const coclass_list[] = { ...@@ -618,7 +673,10 @@ static struct regsvr_coclass const coclass_list[] = {
"shdocvw.dll", "shdocvw.dll",
"Apartment", "Apartment",
NULL, NULL,
NULL NULL,
NULL,
SHELLFOLDER_ATTRIBUTES,
SFGAO_CANDELETE|SFGAO_CANLINK
}, },
{ NULL } /* list terminator */ { NULL } /* list terminator */
}; };
......
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