Chromium Code Reviews| Index: Source/core/dom/NodeIterator.cpp |
| diff --git a/Source/core/dom/NodeIterator.cpp b/Source/core/dom/NodeIterator.cpp |
| index 6a0f76abeb7c6a178e5bff8f60a874101c45007b..678ad9baeb40ce1b1d5029969f2b72f13e7233f0 100644 |
| --- a/Source/core/dom/NodeIterator.cpp |
| +++ b/Source/core/dom/NodeIterator.cpp |
| @@ -29,7 +29,6 @@ |
| #include "core/dom/Document.h" |
| #include "core/dom/ExceptionCode.h" |
| #include "core/dom/NodeTraversal.h" |
| -#include "core/frame/UseCounter.h" |
| namespace WebCore { |
| @@ -37,7 +36,7 @@ NodeIterator::NodePointer::NodePointer() |
| { |
| } |
| -NodeIterator::NodePointer::NodePointer(PassRefPtr<Node> n, bool b) |
| +NodeIterator::NodePointer::NodePointer(PassRefPtrWillBeRawPtr<Node> n, bool b) |
| : node(n) |
| , isPointerBeforeNode(b) |
| { |
| @@ -72,7 +71,7 @@ bool NodeIterator::NodePointer::moveToPrevious(Node* root) |
| return node; |
| } |
| -NodeIterator::NodeIterator(PassRefPtr<Node> rootNode, unsigned whatToShow, PassRefPtr<NodeFilter> filter) |
| +NodeIterator::NodeIterator(PassRefPtrWillBeRawPtr<Node> rootNode, unsigned whatToShow, PassRefPtrWillBeRawPtr<NodeFilter> filter) |
| : NodeIteratorBase(rootNode, whatToShow, filter) |
| , m_referenceNode(root(), true) |
| { |
| @@ -80,21 +79,23 @@ NodeIterator::NodeIterator(PassRefPtr<Node> rootNode, unsigned whatToShow, PassR |
| root()->document().attachNodeIterator(this); |
| } |
| +#if !ENABLE(OILPAN) |
|
haraken
2014/05/18 08:45:48
Nit: We normally write '#if !ENABLE(OILPAN)' insid
sof
2014/05/18 17:19:24
Moved the #if inward.
|
| NodeIterator::~NodeIterator() |
| { |
| root()->document().detachNodeIterator(this); |
| } |
| +#endif |
| -PassRefPtr<Node> NodeIterator::nextNode(ExceptionState& exceptionState) |
| +PassRefPtrWillBeRawPtr<Node> NodeIterator::nextNode(ExceptionState& exceptionState) |
| { |
| - RefPtr<Node> result; |
| + RefPtrWillBeRawPtr<Node> result = nullptr; |
| m_candidateNode = m_referenceNode; |
| while (m_candidateNode.moveToNext(root())) { |
| // NodeIterators treat the DOM tree as a flat list of nodes. |
| // In other words, FILTER_REJECT does not pass over descendants |
| // of the rejected node. Hence, FILTER_REJECT is the same as FILTER_SKIP. |
| - RefPtr<Node> provisionalResult = m_candidateNode.node; |
| + RefPtrWillBeRawPtr<Node> provisionalResult = m_candidateNode.node; |
| bool nodeWasAccepted = acceptNode(provisionalResult.get(), exceptionState) == NodeFilter::FILTER_ACCEPT; |
| if (exceptionState.hadException()) |
| break; |
| @@ -109,16 +110,16 @@ PassRefPtr<Node> NodeIterator::nextNode(ExceptionState& exceptionState) |
| return result.release(); |
| } |
| -PassRefPtr<Node> NodeIterator::previousNode(ExceptionState& exceptionState) |
| +PassRefPtrWillBeRawPtr<Node> NodeIterator::previousNode(ExceptionState& exceptionState) |
| { |
| - RefPtr<Node> result; |
| + RefPtrWillBeRawPtr<Node> result = nullptr; |
| m_candidateNode = m_referenceNode; |
| while (m_candidateNode.moveToPrevious(root())) { |
| // NodeIterators treat the DOM tree as a flat list of nodes. |
| // In other words, FILTER_REJECT does not pass over descendants |
| // of the rejected node. Hence, FILTER_REJECT is the same as FILTER_SKIP. |
| - RefPtr<Node> provisionalResult = m_candidateNode.node; |
| + RefPtrWillBeRawPtr<Node> provisionalResult = m_candidateNode.node; |
| bool nodeWasAccepted = acceptNode(provisionalResult.get(), exceptionState) == NodeFilter::FILTER_ACCEPT; |
| if (exceptionState.hadException()) |
| break; |
| @@ -152,7 +153,7 @@ void NodeIterator::updateForNodeRemoval(Node& removedNode, NodePointer& referenc |
| // or if removed node is not the reference node, or the ancestor of the reference node. |
| if (!removedNode.isDescendantOf(root())) |
| return; |
| - bool willRemoveReferenceNode = removedNode == referenceNode.node; |
| + bool willRemoveReferenceNode = removedNode == referenceNode.node.get(); |
| bool willRemoveReferenceNodeAncestor = referenceNode.node && referenceNode.node->isDescendantOf(&removedNode); |
| if (!willRemoveReferenceNode && !willRemoveReferenceNodeAncestor) |
| return; |
| @@ -210,5 +211,11 @@ void NodeIterator::updateForNodeRemoval(Node& removedNode, NodePointer& referenc |
| } |
| } |
| +void NodeIterator::trace(Visitor* visitor) |
| +{ |
| + visitor->trace(m_referenceNode); |
| + visitor->trace(m_candidateNode); |
| + NodeIteratorBase::trace(visitor); |
| +} |
| } // namespace WebCore |