Commit be419251 authored by Piotr Caban's avatar Piotr Caban Committed by Alexandre Julliard

urlmon: Search for MIME filters defined in registry in get_mime_filter.

parent b36cb0b9
...@@ -260,9 +260,17 @@ HRESULT get_protocol_handler(IUri *uri, CLSID *clsid, BOOL *urlmon_protocol, ICl ...@@ -260,9 +260,17 @@ HRESULT get_protocol_handler(IUri *uri, CLSID *clsid, BOOL *urlmon_protocol, ICl
IInternetProtocol *get_mime_filter(LPCWSTR mime) IInternetProtocol *get_mime_filter(LPCWSTR mime)
{ {
static const WCHAR filtersW[] = {'P','r','o','t','o','c','o','l','s',
'\\','F','i','l','t','e','r',0 };
static const WCHAR CLSIDW[] = {'C','L','S','I','D',0};
IClassFactory *cf = NULL; IClassFactory *cf = NULL;
IInternetProtocol *ret; IInternetProtocol *ret;
mime_filter *iter; mime_filter *iter;
HKEY hlist, hfilter;
WCHAR clsidw[64];
CLSID clsid;
DWORD res, type, size;
HRESULT hres; HRESULT hres;
EnterCriticalSection(&session_cs); EnterCriticalSection(&session_cs);
...@@ -276,12 +284,44 @@ IInternetProtocol *get_mime_filter(LPCWSTR mime) ...@@ -276,12 +284,44 @@ IInternetProtocol *get_mime_filter(LPCWSTR mime)
LeaveCriticalSection(&session_cs); LeaveCriticalSection(&session_cs);
if(!cf) if(cf) {
hres = IClassFactory_CreateInstance(cf, NULL, &IID_IInternetProtocol, (void**)&ret);
if(FAILED(hres)) {
WARN("CreateInstance failed: %08x\n", hres);
return NULL;
}
return ret;
}
res = RegOpenKeyW(HKEY_CLASSES_ROOT, filtersW, &hlist);
if(res != ERROR_SUCCESS) {
TRACE("Could not open MIME filters key\n");
return NULL;
}
res = RegOpenKeyW(hlist, mime, &hfilter);
CloseHandle(hlist);
if(res != ERROR_SUCCESS)
return NULL;
size = sizeof(clsidw);
res = RegQueryValueExW(hfilter, CLSIDW, NULL, &type, (LPBYTE)clsidw, &size);
CloseHandle(hfilter);
if(res!=ERROR_SUCCESS || type!=REG_SZ) {
WARN("Could not get filter CLSID for %s\n", debugstr_w(mime));
return NULL; return NULL;
}
hres = CLSIDFromString(clsidw, &clsid);
if(FAILED(hres)) {
WARN("CLSIDFromString failed for %s (%x)\n", debugstr_w(mime), hres);
return NULL;
}
hres = IClassFactory_CreateInstance(cf, NULL, &IID_IInternetProtocol, (void**)&ret); hres = CoCreateInstance(&clsid, NULL, CLSCTX_INPROC_SERVER, &IID_IInternetProtocol, (void**)&ret);
if(FAILED(hres)) { if(FAILED(hres)) {
WARN("CreateInstance failed: %08x\n", hres); WARN("CoCreateInstance failed: %08x\n", hres);
return NULL; return NULL;
} }
......
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