Commit 4678a859 authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

mshtml: Added IDOMEvent::get_bubbles implementation.

parent 1508eb48
...@@ -976,8 +976,11 @@ static HRESULT WINAPI DOMEvent_Invoke(IDOMEvent *iface, DISPID dispIdMember, ...@@ -976,8 +976,11 @@ static HRESULT WINAPI DOMEvent_Invoke(IDOMEvent *iface, DISPID dispIdMember,
static HRESULT WINAPI DOMEvent_get_bubbles(IDOMEvent *iface, VARIANT_BOOL *p) static HRESULT WINAPI DOMEvent_get_bubbles(IDOMEvent *iface, VARIANT_BOOL *p)
{ {
DOMEvent *This = impl_from_IDOMEvent(iface); DOMEvent *This = impl_from_IDOMEvent(iface);
FIXME("(%p)->(%p)\n", This, p);
return E_NOTIMPL; TRACE("(%p)->(%p)\n", This, p);
*p = variant_bool(This->bubbles);
return S_OK;
} }
static HRESULT WINAPI DOMEvent_get_cancelable(IDOMEvent *iface, VARIANT_BOOL *p) static HRESULT WINAPI DOMEvent_get_cancelable(IDOMEvent *iface, VARIANT_BOOL *p)
...@@ -1164,6 +1167,7 @@ static DOMEvent *alloc_event(nsIDOMEvent *nsevent, eventid_t event_id) ...@@ -1164,6 +1167,7 @@ static DOMEvent *alloc_event(nsIDOMEvent *nsevent, eventid_t event_id)
IDOMEvent_Release(&event->IDOMEvent_iface); IDOMEvent_Release(&event->IDOMEvent_iface);
return NULL; return NULL;
} }
event->bubbles = (event_info[event_id].flags & EVENT_BUBBLES) != 0;
} }
nsIDOMEvent_AddRef(event->nsevent = nsevent); nsIDOMEvent_AddRef(event->nsevent = nsevent);
return event; return event;
...@@ -1523,7 +1527,6 @@ void dispatch_event(EventTarget *event_target, DOMEvent *event) ...@@ -1523,7 +1527,6 @@ void dispatch_event(EventTarget *event_target, DOMEvent *event)
HTMLEventObj *event_obj_ref = NULL; HTMLEventObj *event_obj_ref = NULL;
IHTMLEventObj *prev_event = NULL; IHTMLEventObj *prev_event = NULL;
EventTarget *iter; EventTarget *iter;
DWORD event_flags;
HRESULT hres; HRESULT hres;
if(event->event_id == EVENTID_LAST) { if(event->event_id == EVENTID_LAST) {
...@@ -1533,7 +1536,6 @@ void dispatch_event(EventTarget *event_target, DOMEvent *event) ...@@ -1533,7 +1536,6 @@ void dispatch_event(EventTarget *event_target, DOMEvent *event)
TRACE("(%p) %s\n", event_target, debugstr_w(event->type)); TRACE("(%p) %s\n", event_target, debugstr_w(event->type));
event_flags = event_info[event->event_id].flags;
iter = event_target; iter = event_target;
IDispatchEx_AddRef(&event_target->dispex.IDispatchEx_iface); IDispatchEx_AddRef(&event_target->dispex.IDispatchEx_iface);
...@@ -1587,7 +1589,7 @@ void dispatch_event(EventTarget *event_target, DOMEvent *event) ...@@ -1587,7 +1589,7 @@ void dispatch_event(EventTarget *event_target, DOMEvent *event)
call_event_handlers(target_chain[0], event); call_event_handlers(target_chain[0], event);
} }
if(event_flags & EVENT_BUBBLES) { if(event->bubbles) {
event->phase = DEP_BUBBLING_PHASE; event->phase = DEP_BUBBLING_PHASE;
for(i = 1; !event->stop_propagation && i < chain_cnt; i++) for(i = 1; !event->stop_propagation && i < chain_cnt; i++)
call_event_handlers(target_chain[i], event); call_event_handlers(target_chain[i], event);
...@@ -1599,7 +1601,7 @@ void dispatch_event(EventTarget *event_target, DOMEvent *event) ...@@ -1599,7 +1601,7 @@ void dispatch_event(EventTarget *event_target, DOMEvent *event)
IHTMLEventObj_Release(prev_event); IHTMLEventObj_Release(prev_event);
} }
if(event_flags & EVENT_HASDEFAULTHANDLERS) { if(event->event_id != EVENTID_LAST && (event_info[event->event_id].flags & EVENT_HASDEFAULTHANDLERS)) {
for(i = 0; !event->prevent_default && i < chain_cnt; i++) { for(i = 0; !event->prevent_default && i < chain_cnt; i++) {
BOOL prevent_default = FALSE; BOOL prevent_default = FALSE;
vtbl = dispex_get_vtbl(&target_chain[i]->dispex); vtbl = dispex_get_vtbl(&target_chain[i]->dispex);
......
...@@ -66,6 +66,7 @@ typedef struct { ...@@ -66,6 +66,7 @@ typedef struct {
eventid_t event_id; eventid_t event_id;
WCHAR *type; WCHAR *type;
EventTarget *target; EventTarget *target;
BOOL bubbles;
BOOL prevent_default; BOOL prevent_default;
BOOL stop_propagation; BOOL stop_propagation;
DOM_EVENT_PHASE phase; DOM_EVENT_PHASE phase;
......
...@@ -2668,6 +2668,7 @@ static void test_create_event(IHTMLDocument2 *doc) ...@@ -2668,6 +2668,7 @@ static void test_create_event(IHTMLDocument2 *doc)
{ {
IDocumentEvent *doc_event; IDocumentEvent *doc_event;
IDOMEvent *event; IDOMEvent *event;
VARIANT_BOOL b;
USHORT phase; USHORT phase;
BSTR str; BSTR str;
HRESULT hres; HRESULT hres;
...@@ -2698,6 +2699,11 @@ static void test_create_event(IHTMLDocument2 *doc) ...@@ -2698,6 +2699,11 @@ static void test_create_event(IHTMLDocument2 *doc)
ok(hres == S_OK, "get_type failed: %08x\n", hres); ok(hres == S_OK, "get_type failed: %08x\n", hres);
ok(!str, "type = %s\n", wine_dbgstr_w(str)); ok(!str, "type = %s\n", wine_dbgstr_w(str));
b = 0xdead;
hres = IDOMEvent_get_bubbles(event, &b);
ok(hres == S_OK, "get_bubbles failed: %08x\n", hres);
ok(!b, "bubbles = %x\n", b);
IDOMEvent_Release(event); IDOMEvent_Release(event);
IDocumentEvent_Release(doc_event); IDocumentEvent_Release(doc_event);
......
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