diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2017-06-27 06:07:23 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2017-06-27 06:07:23 +0000 |
commit | 1bf1084f2b10c3b47fd1a588d85d21ed0eb41d0c (patch) | |
tree | 46dcd36c86e7fbc6e5df36deb463b33e9967a6f7 /Source/WebCore/editing/RemoveNodeCommand.cpp | |
parent | 32761a6cee1d0dee366b885b7b9c777e67885688 (diff) | |
download | WebKitGtk-tarball-master.tar.gz |
webkitgtk-2.16.5HEADwebkitgtk-2.16.5master
Diffstat (limited to 'Source/WebCore/editing/RemoveNodeCommand.cpp')
-rw-r--r-- | Source/WebCore/editing/RemoveNodeCommand.cpp | 28 |
1 files changed, 13 insertions, 15 deletions
diff --git a/Source/WebCore/editing/RemoveNodeCommand.cpp b/Source/WebCore/editing/RemoveNodeCommand.cpp index 67d9c56d6..916a4f8c3 100644 --- a/Source/WebCore/editing/RemoveNodeCommand.cpp +++ b/Source/WebCore/editing/RemoveNodeCommand.cpp @@ -10,10 +10,10 @@ * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * - * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY + * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR - * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR @@ -26,19 +26,17 @@ #include "config.h" #include "RemoveNodeCommand.h" -#include "ExceptionCodePlaceholder.h" -#include "Node.h" #include "RenderElement.h" +#include "htmlediting.h" #include <wtf/Assertions.h> namespace WebCore { -RemoveNodeCommand::RemoveNodeCommand(PassRefPtr<Node> node, ShouldAssumeContentIsAlwaysEditable shouldAssumeContentIsAlwaysEditable) - : SimpleEditCommand(node->document()) - , m_node(node) +RemoveNodeCommand::RemoveNodeCommand(Ref<Node>&& node, ShouldAssumeContentIsAlwaysEditable shouldAssumeContentIsAlwaysEditable, EditAction editingAction) + : SimpleEditCommand(node->document(), editingAction) + , m_node(WTFMove(node)) , m_shouldAssumeContentIsAlwaysEditable(shouldAssumeContentIsAlwaysEditable) { - ASSERT(m_node); ASSERT(m_node->parentNode()); } @@ -46,24 +44,24 @@ void RemoveNodeCommand::doApply() { ContainerNode* parent = m_node->parentNode(); if (!parent || (m_shouldAssumeContentIsAlwaysEditable == DoNotAssumeContentIsAlwaysEditable - && !parent->isContentEditable(Node::UserSelectAllIsAlwaysNonEditable) && parent->renderer())) + && !isEditableNode(*parent) && parent->renderer())) return; - ASSERT(parent->isContentEditable(Node::UserSelectAllIsAlwaysNonEditable) || !parent->renderer()); + ASSERT(isEditableNode(*parent) || !parent->renderer()); m_parent = parent; m_refChild = m_node->nextSibling(); - m_node->remove(IGNORE_EXCEPTION); + m_node->remove(); } void RemoveNodeCommand::doUnapply() { - RefPtr<ContainerNode> parent = m_parent.release(); - RefPtr<Node> refChild = m_refChild.release(); + RefPtr<ContainerNode> parent = WTFMove(m_parent); + RefPtr<Node> refChild = WTFMove(m_refChild); if (!parent || !parent->hasEditableStyle()) return; - parent->insertBefore(m_node.get(), refChild.get(), IGNORE_EXCEPTION); + parent->insertBefore(m_node, refChild.get()); } #ifndef NDEBUG @@ -71,7 +69,7 @@ void RemoveNodeCommand::getNodesInCommand(HashSet<Node*>& nodes) { addNodeAndDescendants(m_parent.get(), nodes); addNodeAndDescendants(m_refChild.get(), nodes); - addNodeAndDescendants(m_node.get(), nodes); + addNodeAndDescendants(m_node.ptr(), nodes); } #endif |