mshtml: Initialize DOMEvent object with compat mode.
Signed-off-by: Jacek Caban <jacek@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
78be56291a
commit
c833238a21
|
@ -2201,7 +2201,7 @@ static BOOL check_event_iface(nsIDOMEvent *event, REFIID riid)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static DOMEvent *alloc_event(nsIDOMEvent *nsevent, eventid_t event_id)
|
static DOMEvent *alloc_event(nsIDOMEvent *nsevent, compat_mode_t compat_mode, eventid_t event_id)
|
||||||
{
|
{
|
||||||
dispex_static_data_t *dispex_data = &DOMEvent_dispex;
|
dispex_static_data_t *dispex_data = &DOMEvent_dispex;
|
||||||
DOMEvent *event = NULL;
|
DOMEvent *event = NULL;
|
||||||
|
@ -2266,11 +2266,11 @@ static DOMEvent *alloc_event(nsIDOMEvent *nsevent, eventid_t event_id)
|
||||||
else
|
else
|
||||||
event->keyboard_event = NULL;
|
event->keyboard_event = NULL;
|
||||||
|
|
||||||
init_dispex(&event->dispex, (IUnknown*)&event->IDOMEvent_iface, dispex_data);
|
init_dispex_with_compat_mode(&event->dispex, (IUnknown*)&event->IDOMEvent_iface, dispex_data, compat_mode);
|
||||||
return event;
|
return event;
|
||||||
}
|
}
|
||||||
|
|
||||||
HRESULT create_event_from_nsevent(nsIDOMEvent *nsevent, DOMEvent **ret_event)
|
HRESULT create_event_from_nsevent(nsIDOMEvent *nsevent, compat_mode_t compat_mode, DOMEvent **ret_event)
|
||||||
{
|
{
|
||||||
eventid_t event_id = EVENTID_LAST;
|
eventid_t event_id = EVENTID_LAST;
|
||||||
DOMEvent *event;
|
DOMEvent *event;
|
||||||
|
@ -2290,7 +2290,7 @@ HRESULT create_event_from_nsevent(nsIDOMEvent *nsevent, DOMEvent **ret_event)
|
||||||
}
|
}
|
||||||
nsAString_Finish(&nsstr);
|
nsAString_Finish(&nsstr);
|
||||||
|
|
||||||
event = alloc_event(nsevent, event_id);
|
event = alloc_event(nsevent, compat_mode, event_id);
|
||||||
if(!event)
|
if(!event)
|
||||||
return E_OUTOFMEMORY;
|
return E_OUTOFMEMORY;
|
||||||
|
|
||||||
|
@ -2313,7 +2313,7 @@ HRESULT create_document_event_str(HTMLDocumentNode *doc, const WCHAR *type, IDOM
|
||||||
return E_FAIL;
|
return E_FAIL;
|
||||||
}
|
}
|
||||||
|
|
||||||
event = alloc_event(nsevent, EVENTID_LAST);
|
event = alloc_event(nsevent, dispex_compat_mode(&doc->node.event_target.dispex), EVENTID_LAST);
|
||||||
nsIDOMEvent_Release(nsevent);
|
nsIDOMEvent_Release(nsevent);
|
||||||
if(!event)
|
if(!event)
|
||||||
return E_OUTOFMEMORY;
|
return E_OUTOFMEMORY;
|
||||||
|
@ -2337,7 +2337,7 @@ HRESULT create_document_event(HTMLDocumentNode *doc, eventid_t event_id, DOMEven
|
||||||
return E_FAIL;
|
return E_FAIL;
|
||||||
}
|
}
|
||||||
|
|
||||||
event = alloc_event(nsevent, event_id);
|
event = alloc_event(nsevent, dispex_compat_mode(&doc->node.event_target.dispex), event_id);
|
||||||
if(!event)
|
if(!event)
|
||||||
return E_OUTOFMEMORY;
|
return E_OUTOFMEMORY;
|
||||||
|
|
||||||
|
|
|
@ -110,7 +110,7 @@ void dispatch_event(EventTarget*,DOMEvent*) DECLSPEC_HIDDEN;
|
||||||
|
|
||||||
HRESULT create_document_event(HTMLDocumentNode*,eventid_t,DOMEvent**) DECLSPEC_HIDDEN;
|
HRESULT create_document_event(HTMLDocumentNode*,eventid_t,DOMEvent**) DECLSPEC_HIDDEN;
|
||||||
HRESULT create_document_event_str(HTMLDocumentNode*,const WCHAR*,IDOMEvent**) DECLSPEC_HIDDEN;
|
HRESULT create_document_event_str(HTMLDocumentNode*,const WCHAR*,IDOMEvent**) DECLSPEC_HIDDEN;
|
||||||
HRESULT create_event_from_nsevent(nsIDOMEvent*,DOMEvent**) DECLSPEC_HIDDEN;
|
HRESULT create_event_from_nsevent(nsIDOMEvent*,compat_mode_t,DOMEvent**) DECLSPEC_HIDDEN;
|
||||||
|
|
||||||
void init_nsevents(HTMLDocumentNode*) DECLSPEC_HIDDEN;
|
void init_nsevents(HTMLDocumentNode*) DECLSPEC_HIDDEN;
|
||||||
void release_nsevents(HTMLDocumentNode*) DECLSPEC_HIDDEN;
|
void release_nsevents(HTMLDocumentNode*) DECLSPEC_HIDDEN;
|
||||||
|
|
|
@ -1659,7 +1659,7 @@ static nsresult NSAPI nsContextMenuListener_OnShowContextMenu(nsIContextMenuList
|
||||||
if(FAILED(hres))
|
if(FAILED(hres))
|
||||||
return NS_ERROR_FAILURE;
|
return NS_ERROR_FAILURE;
|
||||||
|
|
||||||
hres = create_event_from_nsevent(aEvent, &event);
|
hres = create_event_from_nsevent(aEvent, dispex_compat_mode(&node->event_target.dispex), &event);
|
||||||
if(SUCCEEDED(hres)) {
|
if(SUCCEEDED(hres)) {
|
||||||
dispatch_event(&node->event_target, event);
|
dispatch_event(&node->event_target, event);
|
||||||
IDOMEvent_Release(&event->IDOMEvent_iface);
|
IDOMEvent_Release(&event->IDOMEvent_iface);
|
||||||
|
|
|
@ -270,7 +270,7 @@ static nsresult NSAPI handle_load(nsIDOMEventListener *iface, nsIDOMEvent *event
|
||||||
}
|
}
|
||||||
|
|
||||||
if(doc->window) {
|
if(doc->window) {
|
||||||
hres = create_event_from_nsevent(event, &load_event);
|
hres = create_event_from_nsevent(event, dispex_compat_mode(&doc->node.event_target.dispex), &load_event);
|
||||||
if(SUCCEEDED(hres)) {
|
if(SUCCEEDED(hres)) {
|
||||||
dispatch_event(&doc->window->event_target, load_event);
|
dispatch_event(&doc->window->event_target, load_event);
|
||||||
IDOMEvent_Release(&load_event->IDOMEvent_iface);
|
IDOMEvent_Release(&load_event->IDOMEvent_iface);
|
||||||
|
@ -319,7 +319,7 @@ static nsresult NSAPI handle_htmlevent(nsIDOMEventListener *iface, nsIDOMEvent *
|
||||||
if(FAILED(hres))
|
if(FAILED(hres))
|
||||||
return NS_OK;
|
return NS_OK;
|
||||||
|
|
||||||
hres = create_event_from_nsevent(nsevent, &event);
|
hres = create_event_from_nsevent(nsevent, dispex_compat_mode(&doc->node.event_target.dispex), &event);
|
||||||
if(FAILED(hres)) {
|
if(FAILED(hres)) {
|
||||||
node_release(node);
|
node_release(node);
|
||||||
return NS_OK;
|
return NS_OK;
|
||||||
|
|
|
@ -205,7 +205,7 @@ static nsresult NSAPI XMLHttpReqEventListener_HandleEvent(nsIDOMEventListener *i
|
||||||
if(!This->xhr)
|
if(!This->xhr)
|
||||||
return NS_OK;
|
return NS_OK;
|
||||||
|
|
||||||
hres = create_event_from_nsevent(nsevent, &event);
|
hres = create_event_from_nsevent(nsevent, dispex_compat_mode(&This->xhr->event_target.dispex), &event);
|
||||||
if(SUCCEEDED(hres) ){
|
if(SUCCEEDED(hres) ){
|
||||||
dispatch_event(&This->xhr->event_target, event);
|
dispatch_event(&This->xhr->event_target, event);
|
||||||
IDOMEvent_Release(&event->IDOMEvent_iface);
|
IDOMEvent_Release(&event->IDOMEvent_iface);
|
||||||
|
|
Loading…
Reference in New Issue