diff options
Diffstat (limited to 'WebCore/dom/ContainerNode.cpp')
-rw-r--r-- | WebCore/dom/ContainerNode.cpp | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/WebCore/dom/ContainerNode.cpp b/WebCore/dom/ContainerNode.cpp index 46de749..2dd50bb 100644 --- a/WebCore/dom/ContainerNode.cpp +++ b/WebCore/dom/ContainerNode.cpp @@ -72,7 +72,6 @@ void ContainerNode::removeAllChildren() removeAllChildrenInContainer<Node, ContainerNode>(this); } - void ContainerNode::takeAllChildrenFrom(ContainerNode* oldParent) { NodeVector children; @@ -82,10 +81,14 @@ void ContainerNode::takeAllChildrenFrom(ContainerNode* oldParent) for (unsigned i = 0; i < children.size(); ++i) { ExceptionCode ec = 0; + if (children[i]->attached()) + children[i]->detach(); // FIXME: We need a no mutation event version of adoptNode. RefPtr<Node> child = document()->adoptNode(children[i].release(), ec); ASSERT(!ec); - parserAddChild(child.release()); + parserAddChild(child.get()); + if (attached() && !child->attached()) + child->attach(); } } @@ -359,9 +362,7 @@ static void willRemoveChild(Node* child) // fire removed from document mutation events. dispatchChildRemovalEvents(child); - - if (child->attached()) - child->willRemove(); + child->willRemove(); } static void willRemoveChildren(ContainerNode* container) @@ -373,9 +374,7 @@ static void willRemoveChildren(ContainerNode* container) for (RefPtr<Node> child = container->firstChild(); child; child = child->nextSibling()) { // fire removed from document mutation events. dispatchChildRemovalEvents(child.get()); - - if (child->attached()) - child->willRemove(); + child->willRemove(); } } |