Commit a8a050e9 authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

mshtml: Added IBindCallbackRedirect implementation.

parent 86f7c4c8
...@@ -69,10 +69,11 @@ typedef struct { ...@@ -69,10 +69,11 @@ typedef struct {
typedef struct BSCallbackVtbl BSCallbackVtbl; typedef struct BSCallbackVtbl BSCallbackVtbl;
struct BSCallback { struct BSCallback {
IBindStatusCallback IBindStatusCallback_iface; IBindStatusCallback IBindStatusCallback_iface;
IServiceProvider IServiceProvider_iface; IServiceProvider IServiceProvider_iface;
IHttpNegotiate2 IHttpNegotiate2_iface; IHttpNegotiate2 IHttpNegotiate2_iface;
IInternetBindInfo IInternetBindInfo_iface; IInternetBindInfo IInternetBindInfo_iface;
IBindCallbackRedirect IBindCallbackRedirect_iface;
const BSCallbackVtbl *vtbl; const BSCallbackVtbl *vtbl;
......
...@@ -248,6 +248,9 @@ static HRESULT WINAPI BindStatusCallback_QueryInterface(IBindStatusCallback *ifa ...@@ -248,6 +248,9 @@ static HRESULT WINAPI BindStatusCallback_QueryInterface(IBindStatusCallback *ifa
}else if(IsEqualGUID(&IID_IInternetBindInfo, riid)) { }else if(IsEqualGUID(&IID_IInternetBindInfo, riid)) {
TRACE("(%p)->(IID_IInternetBindInfo %p)\n", This, ppv); TRACE("(%p)->(IID_IInternetBindInfo %p)\n", This, ppv);
*ppv = &This->IInternetBindInfo_iface; *ppv = &This->IInternetBindInfo_iface;
}else if(IsEqualGUID(&IID_IBindCallbackRedirect, riid)) {
TRACE("(%p)->(IID_IBindCallbackRedirect %p)\n", This, ppv);
*ppv = &This->IBindCallbackRedirect_iface;
} }
if(*ppv) { if(*ppv) {
...@@ -561,6 +564,63 @@ static const IInternetBindInfoVtbl InternetBindInfoVtbl = { ...@@ -561,6 +564,63 @@ static const IInternetBindInfoVtbl InternetBindInfoVtbl = {
InternetBindInfo_GetBindString InternetBindInfo_GetBindString
}; };
static inline BSCallback *impl_from_IBindCallbackRedirect(IBindCallbackRedirect *iface)
{
return CONTAINING_RECORD(iface, BSCallback, IBindCallbackRedirect_iface);
}
static HRESULT WINAPI BindCallbackRedirect_QueryInterface(IBindCallbackRedirect *iface, REFIID riid, void **ppv)
{
BSCallback *This = impl_from_IBindCallbackRedirect(iface);
return IBindStatusCallback_QueryInterface(&This->IBindStatusCallback_iface, riid, ppv);
}
static ULONG WINAPI BindCallbackRedirect_AddRef(IBindCallbackRedirect *iface)
{
BSCallback *This = impl_from_IBindCallbackRedirect(iface);
return IBindStatusCallback_AddRef(&This->IBindStatusCallback_iface);
}
static ULONG WINAPI BindCallbackRedirect_Release(IBindCallbackRedirect *iface)
{
BSCallback *This = impl_from_IBindCallbackRedirect(iface);
return IBindStatusCallback_Release(&This->IBindStatusCallback_iface);
}
static HRESULT WINAPI BindCallbackRedirect_Redirect(IBindCallbackRedirect *iface, const WCHAR *url, VARIANT_BOOL *vbCancel)
{
BSCallback *This = impl_from_IBindCallbackRedirect(iface);
HTMLDocumentObj *doc_obj;
BOOL cancel = FALSE;
BSTR frame_name = NULL;
HRESULT hres = S_OK;
TRACE("(%p)->(%s %p)\n", This, debugstr_w(url), vbCancel);
if(This->window && This->window->base.outer_window && (doc_obj = This->window->base.outer_window->doc_obj)
&& doc_obj->doc_object_service) {
if(This->window->base.outer_window != doc_obj->basedoc.window) {
hres = IHTMLWindow2_get_name(&This->window->base.IHTMLWindow2_iface, &frame_name);
if(FAILED(hres))
return hres;
}
hres = IDocObjectService_FireBeforeNavigate2(doc_obj->doc_object_service, NULL, url, 0x40,
frame_name, NULL, 0, NULL, TRUE, &cancel);
SysFreeString(frame_name);
}
*vbCancel = cancel ? VARIANT_TRUE : VARIANT_FALSE;
return hres;
}
static const IBindCallbackRedirectVtbl BindCallbackRedirectVtbl = {
BindCallbackRedirect_QueryInterface,
BindCallbackRedirect_AddRef,
BindCallbackRedirect_Release,
BindCallbackRedirect_Redirect
};
static inline BSCallback *impl_from_IServiceProvider(IServiceProvider *iface) static inline BSCallback *impl_from_IServiceProvider(IServiceProvider *iface)
{ {
return CONTAINING_RECORD(iface, BSCallback, IServiceProvider_iface); return CONTAINING_RECORD(iface, BSCallback, IServiceProvider_iface);
...@@ -610,6 +670,7 @@ void init_bscallback(BSCallback *This, const BSCallbackVtbl *vtbl, IMoniker *mon ...@@ -610,6 +670,7 @@ void init_bscallback(BSCallback *This, const BSCallbackVtbl *vtbl, IMoniker *mon
This->IServiceProvider_iface.lpVtbl = &ServiceProviderVtbl; This->IServiceProvider_iface.lpVtbl = &ServiceProviderVtbl;
This->IHttpNegotiate2_iface.lpVtbl = &HttpNegotiate2Vtbl; This->IHttpNegotiate2_iface.lpVtbl = &HttpNegotiate2Vtbl;
This->IInternetBindInfo_iface.lpVtbl = &InternetBindInfoVtbl; This->IInternetBindInfo_iface.lpVtbl = &InternetBindInfoVtbl;
This->IBindCallbackRedirect_iface.lpVtbl = &BindCallbackRedirectVtbl;
This->vtbl = vtbl; This->vtbl = vtbl;
This->ref = 1; This->ref = 1;
This->bindf = bindf; This->bindf = bindf;
......
...@@ -1469,6 +1469,8 @@ static HRESULT WINAPI Moniker_BindToStorage(IMoniker *iface, IBindCtx *pbc, IMon ...@@ -1469,6 +1469,8 @@ static HRESULT WINAPI Moniker_BindToStorage(IMoniker *iface, IBindCtx *pbc, IMon
REFIID riid, void **ppv) REFIID riid, void **ppv)
{ {
IBindStatusCallback *callback = NULL; IBindStatusCallback *callback = NULL;
IBindCallbackRedirect *redirect_callback;
IServiceProvider *service_provider;
BINDINFO bindinfo; BINDINFO bindinfo;
DWORD bindf; DWORD bindf;
HRESULT hres; HRESULT hres;
...@@ -1511,6 +1513,15 @@ static HRESULT WINAPI Moniker_BindToStorage(IMoniker *iface, IBindCtx *pbc, IMon ...@@ -1511,6 +1513,15 @@ static HRESULT WINAPI Moniker_BindToStorage(IMoniker *iface, IBindCtx *pbc, IMon
ok(bindinfo.pUnk == NULL, "bindinfo.pUnk=%p\n", bindinfo.pUnk); ok(bindinfo.pUnk == NULL, "bindinfo.pUnk=%p\n", bindinfo.pUnk);
ok(bindinfo.dwReserved == 0, "bindinfo.dwReserved=%d\n", bindinfo.dwReserved); ok(bindinfo.dwReserved == 0, "bindinfo.dwReserved=%d\n", bindinfo.dwReserved);
hres = IBindStatusCallback_QueryInterface(callback, &IID_IServiceProvider, (void**)&service_provider);
ok(hres == S_OK, "Could not get IServiceProvider iface: %08x\n", hres);
hres = IServiceProvider_QueryService(service_provider, &IID_IBindCallbackRedirect, &IID_IBindCallbackRedirect, (void**)&redirect_callback);
ok(hres == S_OK, "QueryService(IID_IBindCallbackRedirect) returned %08x\n", hres);
IBindCallbackRedirect_Release(redirect_callback);
IServiceProvider_Release(service_provider);
hres = IBindStatusCallback_OnStartBinding(callback, 0, &Binding); hres = IBindStatusCallback_OnStartBinding(callback, 0, &Binding);
ok(hres == S_OK, "OnStartBinding failed: %08x\n", hres); ok(hres == S_OK, "OnStartBinding failed: %08x\n", hres);
......
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