mshtml: Initialize node object from child node's constructors.
This commit is contained in:
parent
bb1190a832
commit
fdf676ac17
|
@ -190,7 +190,7 @@ static dispex_static_data_t HTMLCommentElement_dispex = {
|
||||||
HTMLCommentElement_iface_tids
|
HTMLCommentElement_iface_tids
|
||||||
};
|
};
|
||||||
|
|
||||||
HTMLElement *HTMLCommentElement_Create(nsIDOMNode *nsnode)
|
HTMLElement *HTMLCommentElement_Create(HTMLDocument *doc, nsIDOMNode *nsnode)
|
||||||
{
|
{
|
||||||
HTMLCommentElement *ret = heap_alloc_zero(sizeof(*ret));
|
HTMLCommentElement *ret = heap_alloc_zero(sizeof(*ret));
|
||||||
|
|
||||||
|
@ -199,6 +199,7 @@ HTMLElement *HTMLCommentElement_Create(nsIDOMNode *nsnode)
|
||||||
|
|
||||||
init_dispex(&ret->element.node.dispex, (IUnknown*)HTMLCOMMENT(ret), &HTMLCommentElement_dispex);
|
init_dispex(&ret->element.node.dispex, (IUnknown*)HTMLCOMMENT(ret), &HTMLCommentElement_dispex);
|
||||||
HTMLElement_Init(&ret->element);
|
HTMLElement_Init(&ret->element);
|
||||||
|
HTMLDOMNode_Init(doc, &ret->element.node, nsnode);
|
||||||
|
|
||||||
return &ret->element;
|
return &ret->element;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1388,7 +1388,7 @@ void HTMLElement_Init(HTMLElement *This)
|
||||||
init_dispex(&This->node.dispex, (IUnknown*)HTMLELEM(This), &HTMLElement_dispex);
|
init_dispex(&This->node.dispex, (IUnknown*)HTMLELEM(This), &HTMLElement_dispex);
|
||||||
}
|
}
|
||||||
|
|
||||||
HTMLElement *HTMLElement_Create(nsIDOMNode *nsnode)
|
HTMLElement *HTMLElement_Create(HTMLDocument *doc, nsIDOMNode *nsnode)
|
||||||
{
|
{
|
||||||
nsIDOMHTMLElement *nselem;
|
nsIDOMHTMLElement *nselem;
|
||||||
HTMLElement *ret = NULL;
|
HTMLElement *ret = NULL;
|
||||||
|
@ -1438,11 +1438,14 @@ HTMLElement *HTMLElement_Create(nsIDOMNode *nsnode)
|
||||||
ret = heap_alloc_zero(sizeof(HTMLElement));
|
ret = heap_alloc_zero(sizeof(HTMLElement));
|
||||||
HTMLElement_Init(ret);
|
HTMLElement_Init(ret);
|
||||||
ret->node.vtbl = &HTMLElementImplVtbl;
|
ret->node.vtbl = &HTMLElementImplVtbl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TRACE("%s ret %p\n", debugstr_w(class_name), ret);
|
||||||
|
|
||||||
nsAString_Finish(&class_name_str);
|
nsAString_Finish(&class_name_str);
|
||||||
|
|
||||||
ret->nselem = nselem;
|
ret->nselem = nselem;
|
||||||
|
HTMLDOMNode_Init(doc, &ret->node, (nsIDOMNode*)nselem);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
|
@ -705,6 +705,20 @@ static const NodeImplVtbl HTMLDOMNodeImplVtbl = {
|
||||||
HTMLDOMNode_destructor
|
HTMLDOMNode_destructor
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void HTMLDOMNode_Init(HTMLDocument *doc, HTMLDOMNode *node, nsIDOMNode *nsnode)
|
||||||
|
{
|
||||||
|
node->lpHTMLDOMNodeVtbl = &HTMLDOMNodeVtbl;
|
||||||
|
node->lpHTMLDOMNode2Vtbl = &HTMLDOMNode2Vtbl;
|
||||||
|
node->ref = 1;
|
||||||
|
node->doc = doc;
|
||||||
|
|
||||||
|
nsIDOMNode_AddRef(nsnode);
|
||||||
|
node->nsnode = nsnode;
|
||||||
|
|
||||||
|
node->next = doc->nodes;
|
||||||
|
doc->nodes = node;
|
||||||
|
}
|
||||||
|
|
||||||
static HTMLDOMNode *create_node(HTMLDocument *doc, nsIDOMNode *nsnode)
|
static HTMLDOMNode *create_node(HTMLDocument *doc, nsIDOMNode *nsnode)
|
||||||
{
|
{
|
||||||
HTMLDOMNode *ret;
|
HTMLDOMNode *ret;
|
||||||
|
@ -714,27 +728,20 @@ static HTMLDOMNode *create_node(HTMLDocument *doc, nsIDOMNode *nsnode)
|
||||||
|
|
||||||
switch(node_type) {
|
switch(node_type) {
|
||||||
case ELEMENT_NODE:
|
case ELEMENT_NODE:
|
||||||
ret = &HTMLElement_Create(nsnode)->node;
|
ret = &HTMLElement_Create(doc, nsnode)->node;
|
||||||
break;
|
break;
|
||||||
case TEXT_NODE:
|
case TEXT_NODE:
|
||||||
ret = HTMLDOMTextNode_Create(nsnode);
|
ret = HTMLDOMTextNode_Create(doc, nsnode);
|
||||||
break;
|
break;
|
||||||
case COMMENT_NODE:
|
case COMMENT_NODE:
|
||||||
ret = &HTMLCommentElement_Create(nsnode)->node;
|
ret = &HTMLCommentElement_Create(doc, nsnode)->node;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
ret = heap_alloc_zero(sizeof(HTMLDOMNode));
|
ret = heap_alloc_zero(sizeof(HTMLDOMNode));
|
||||||
ret->vtbl = &HTMLDOMNodeImplVtbl;
|
ret->vtbl = &HTMLDOMNodeImplVtbl;
|
||||||
|
HTMLDOMNode_Init(doc, ret, nsnode);
|
||||||
}
|
}
|
||||||
|
|
||||||
ret->lpHTMLDOMNodeVtbl = &HTMLDOMNodeVtbl;
|
|
||||||
ret->lpHTMLDOMNode2Vtbl = &HTMLDOMNode2Vtbl;
|
|
||||||
ret->ref = 1;
|
|
||||||
ret->doc = doc;
|
|
||||||
|
|
||||||
nsIDOMNode_AddRef(nsnode);
|
|
||||||
ret->nsnode = nsnode;
|
|
||||||
|
|
||||||
TRACE("type %d ret %p\n", node_type, ret);
|
TRACE("type %d ret %p\n", node_type, ret);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -748,7 +755,7 @@ static HTMLDOMNode *create_node(HTMLDocument *doc, nsIDOMNode *nsnode)
|
||||||
|
|
||||||
HTMLDOMNode *get_node(HTMLDocument *This, nsIDOMNode *nsnode, BOOL create)
|
HTMLDOMNode *get_node(HTMLDocument *This, nsIDOMNode *nsnode, BOOL create)
|
||||||
{
|
{
|
||||||
HTMLDOMNode *iter = This->nodes, *ret;
|
HTMLDOMNode *iter = This->nodes;
|
||||||
|
|
||||||
while(iter) {
|
while(iter) {
|
||||||
if(iter->nsnode == nsnode)
|
if(iter->nsnode == nsnode)
|
||||||
|
@ -759,12 +766,7 @@ HTMLDOMNode *get_node(HTMLDocument *This, nsIDOMNode *nsnode, BOOL create)
|
||||||
if(iter || !create)
|
if(iter || !create)
|
||||||
return iter;
|
return iter;
|
||||||
|
|
||||||
ret = create_node(This, nsnode);
|
return create_node(This, nsnode);
|
||||||
|
|
||||||
ret->next = This->nodes;
|
|
||||||
This->nodes = ret;
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void release_nodes(HTMLDocument *This)
|
void release_nodes(HTMLDocument *This)
|
||||||
|
|
|
@ -198,7 +198,7 @@ static dispex_static_data_t HTMLDOMTextNode_dispex = {
|
||||||
HTMLDOMTextNode_iface_tids
|
HTMLDOMTextNode_iface_tids
|
||||||
};
|
};
|
||||||
|
|
||||||
HTMLDOMNode *HTMLDOMTextNode_Create(nsIDOMNode *nsnode)
|
HTMLDOMNode *HTMLDOMTextNode_Create(HTMLDocument *doc, nsIDOMNode *nsnode)
|
||||||
{
|
{
|
||||||
HTMLDOMTextNode *ret ;
|
HTMLDOMTextNode *ret ;
|
||||||
|
|
||||||
|
@ -207,6 +207,7 @@ HTMLDOMNode *HTMLDOMTextNode_Create(nsIDOMNode *nsnode)
|
||||||
ret->lpIHTMLDOMTextNodeVtbl = &HTMLDOMTextNodeVtbl;
|
ret->lpIHTMLDOMTextNodeVtbl = &HTMLDOMTextNodeVtbl;
|
||||||
|
|
||||||
init_dispex(&ret->node.dispex, (IUnknown*)HTMLTEXT(ret), &HTMLDOMTextNode_dispex);
|
init_dispex(&ret->node.dispex, (IUnknown*)HTMLTEXT(ret), &HTMLDOMTextNode_dispex);
|
||||||
|
HTMLDOMNode_Init(doc, &ret->node, nsnode);
|
||||||
|
|
||||||
return &ret->node;
|
return &ret->node;
|
||||||
}
|
}
|
||||||
|
|
|
@ -519,10 +519,10 @@ IHTMLStyleSheetsCollection *HTMLStyleSheetsCollection_Create(nsIDOMStyleSheetLis
|
||||||
void detach_selection(HTMLDocument*);
|
void detach_selection(HTMLDocument*);
|
||||||
void detach_ranges(HTMLDocument*);
|
void detach_ranges(HTMLDocument*);
|
||||||
|
|
||||||
HTMLDOMNode *HTMLDOMTextNode_Create(nsIDOMNode*);
|
HTMLDOMNode *HTMLDOMTextNode_Create(HTMLDocument*,nsIDOMNode*);
|
||||||
|
|
||||||
HTMLElement *HTMLElement_Create(nsIDOMNode*);
|
HTMLElement *HTMLElement_Create(HTMLDocument*,nsIDOMNode*);
|
||||||
HTMLElement *HTMLCommentElement_Create(nsIDOMNode*);
|
HTMLElement *HTMLCommentElement_Create(HTMLDocument*,nsIDOMNode*);
|
||||||
HTMLElement *HTMLAnchorElement_Create(nsIDOMHTMLElement*);
|
HTMLElement *HTMLAnchorElement_Create(nsIDOMHTMLElement*);
|
||||||
HTMLElement *HTMLBodyElement_Create(nsIDOMHTMLElement*);
|
HTMLElement *HTMLBodyElement_Create(nsIDOMHTMLElement*);
|
||||||
HTMLElement *HTMLImgElement_Create(nsIDOMHTMLElement*);
|
HTMLElement *HTMLImgElement_Create(nsIDOMHTMLElement*);
|
||||||
|
@ -533,6 +533,7 @@ HTMLElement *HTMLSelectElement_Create(nsIDOMHTMLElement*);
|
||||||
HTMLElement *HTMLTable_Create(nsIDOMHTMLElement*);
|
HTMLElement *HTMLTable_Create(nsIDOMHTMLElement*);
|
||||||
HTMLElement *HTMLTextAreaElement_Create(nsIDOMHTMLElement*);
|
HTMLElement *HTMLTextAreaElement_Create(nsIDOMHTMLElement*);
|
||||||
|
|
||||||
|
void HTMLDOMNode_Init(HTMLDocument*,HTMLDOMNode*,nsIDOMNode*);
|
||||||
void HTMLElement_Init(HTMLElement*);
|
void HTMLElement_Init(HTMLElement*);
|
||||||
void HTMLElement2_Init(HTMLElement*);
|
void HTMLElement2_Init(HTMLElement*);
|
||||||
void HTMLTextContainer_Init(HTMLTextContainer*);
|
void HTMLTextContainer_Init(HTMLTextContainer*);
|
||||||
|
|
Loading…
Reference in New Issue