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

mshtml: Pass event target as EventTarget to release_event_target.

parent 57239e78
......@@ -1642,20 +1642,25 @@ HRESULT doc_init_events(HTMLDocumentNode *doc)
return S_OK;
}
void release_event_target(event_target_t *event_target)
void release_event_target(EventTarget *event_target)
{
int i;
unsigned int j;
if(!event_target->ptr)
return;
for(i=0; i < EVENTID_LAST; i++) {
if(event_target->event_table[i]) {
if(event_target->event_table[i]->handler_prop)
IDispatch_Release(event_target->event_table[i]->handler_prop);
for(j=0; j < event_target->event_table[i]->handler_cnt; j++)
if(event_target->event_table[i]->handlers[j])
IDispatch_Release(event_target->event_table[i]->handlers[j]);
if(event_target->ptr->event_table[i]) {
if(event_target->ptr->event_table[i]->handler_prop)
IDispatch_Release(event_target->ptr->event_table[i]->handler_prop);
for(j=0; j < event_target->ptr->event_table[i]->handler_cnt; j++)
if(event_target->ptr->event_table[i]->handlers[j])
IDispatch_Release(event_target->ptr->event_table[i]->handlers[j]);
heap_free(event_target->ptr->event_table[i]->handlers);
heap_free(event_target->ptr->event_table[i]);
}
}
heap_free(event_target);
heap_free(event_target->ptr);
}
......@@ -55,7 +55,7 @@ typedef enum {
eventid_t str_to_eid(LPCWSTR) DECLSPEC_HIDDEN;
void check_event_attr(HTMLDocumentNode*,nsIDOMHTMLElement*) DECLSPEC_HIDDEN;
void release_event_target(event_target_t*) DECLSPEC_HIDDEN;
void release_event_target(EventTarget*) DECLSPEC_HIDDEN;
void fire_event(HTMLDocumentNode*,eventid_t,BOOL,HTMLDOMNode*,nsIDOMEvent*,IDispatch*) DECLSPEC_HIDDEN;
HRESULT set_event_handler(EventTarget*,eventid_t,VARIANT*) DECLSPEC_HIDDEN;
HRESULT get_event_handler(EventTarget*,eventid_t,VARIANT*) DECLSPEC_HIDDEN;
......
......@@ -1185,12 +1185,11 @@ HRESULT HTMLDOMNode_QI(HTMLDOMNode *This, REFIID riid, void **ppv)
void HTMLDOMNode_destructor(HTMLDOMNode *This)
{
release_event_target(&This->event_target);
if(This->nsnode)
nsIDOMNode_Release(This->nsnode);
if(This->doc && &This->doc->node != This)
htmldoc_release(&This->doc->basedoc);
if(This->event_target.ptr)
release_event_target(This->event_target.ptr);
}
static HRESULT HTMLDOMNode_clone(HTMLDOMNode *This, nsIDOMNode *nsnode, HTMLDOMNode **ret)
......
......@@ -253,8 +253,7 @@ static void release_inner_window(HTMLInnerWindow *This)
htmldoc_release(&This->doc->basedoc);
}
if(This->event_target.ptr)
release_event_target(This->event_target.ptr);
release_event_target(&This->event_target);
release_dispex(&This->event_target.dispex);
for(i=0; i < This->global_prop_cnt; i++)
......
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