#include "config.h"
#include "core/editing/MergeIdenticalElementsCommand.h"
-#include "bindings/v8/ExceptionState.h"
-#include "bindings/v8/ExceptionStatePlaceholder.h"
+#include "bindings/core/v8/ExceptionState.h"
+#include "bindings/core/v8/ExceptionStatePlaceholder.h"
#include "core/dom/Element.h"
-namespace WebCore {
+namespace blink {
-MergeIdenticalElementsCommand::MergeIdenticalElementsCommand(PassRefPtr<Element> first, PassRefPtr<Element> second)
+MergeIdenticalElementsCommand::MergeIdenticalElementsCommand(PassRefPtrWillBeRawPtr<Element> first, PassRefPtrWillBeRawPtr<Element> second)
: SimpleEditCommand(first->document())
, m_element1(first)
, m_element2(second)
void MergeIdenticalElementsCommand::doApply()
{
- if (m_element1->nextSibling() != m_element2 || !m_element1->rendererIsEditable() || !m_element2->rendererIsEditable())
+ if (m_element1->nextSibling() != m_element2 || !m_element1->hasEditableStyle() || !m_element2->hasEditableStyle())
return;
m_atChild = m_element2->firstChild();
- Vector<RefPtr<Node> > children;
- for (Node* child = m_element1->firstChild(); child; child = child->nextSibling())
- children.append(child);
+ NodeVector children;
+ getChildNodes(*m_element1, children);
- size_t size = children.size();
- for (size_t i = 0; i < size; ++i)
- m_element2->insertBefore(children[i].release(), m_atChild.get(), IGNORE_EXCEPTION);
+ for (auto& child : children)
+ m_element2->insertBefore(child.release(), m_atChild.get(), IGNORE_EXCEPTION);
m_element1->remove(IGNORE_EXCEPTION);
}
ASSERT(m_element1);
ASSERT(m_element2);
- RefPtr<Node> atChild = m_atChild.release();
+ RefPtrWillBeRawPtr<Node> atChild = m_atChild.release();
ContainerNode* parent = m_element2->parentNode();
- if (!parent || !parent->rendererIsEditable())
+ if (!parent || !parent->hasEditableStyle())
return;
TrackExceptionState exceptionState;
if (exceptionState.hadException())
return;
- Vector<RefPtr<Node> > children;
+ WillBeHeapVector<RefPtrWillBeMember<Node>> children;
for (Node* child = m_element2->firstChild(); child && child != atChild; child = child->nextSibling())
children.append(child);
- size_t size = children.size();
- for (size_t i = 0; i < size; ++i)
- m_element1->appendChild(children[i].release(), exceptionState);
+ for (auto& child : children)
+ m_element1->appendChild(child.release(), exceptionState);
+}
+
+void MergeIdenticalElementsCommand::trace(Visitor* visitor)
+{
+ visitor->trace(m_element1);
+ visitor->trace(m_element2);
+ visitor->trace(m_atChild);
+ SimpleEditCommand::trace(visitor);
}
-} // namespace WebCore
+} // namespace blink