OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) | 2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) |
3 * Copyright (C) 2000 Frederik Holljen (frederik.holljen@hig.no) | 3 * Copyright (C) 2000 Frederik Holljen (frederik.holljen@hig.no) |
4 * Copyright (C) 2001 Peter Kelly (pmk@post.com) | 4 * Copyright (C) 2001 Peter Kelly (pmk@post.com) |
5 * Copyright (C) 2006 Samuel Weinig (sam.weinig@gmail.com) | 5 * Copyright (C) 2006 Samuel Weinig (sam.weinig@gmail.com) |
6 * Copyright (C) 2004, 2008 Apple Inc. All rights reserved. | 6 * Copyright (C) 2004, 2008 Apple Inc. All rights reserved. |
7 * | 7 * |
8 * This library is free software; you can redistribute it and/or | 8 * This library is free software; you can redistribute it and/or |
9 * modify it under the terms of the GNU Library General Public | 9 * modify it under the terms of the GNU Library General Public |
10 * License as published by the Free Software Foundation; either | 10 * License as published by the Free Software Foundation; either |
(...skipping 19 matching lines...) Expand all Loading... |
30 #include "core/dom/Traversal.h" | 30 #include "core/dom/Traversal.h" |
31 #include <wtf/PassRefPtr.h> | 31 #include <wtf/PassRefPtr.h> |
32 #include <wtf/RefCounted.h> | 32 #include <wtf/RefCounted.h> |
33 | 33 |
34 namespace WebCore { | 34 namespace WebCore { |
35 | 35 |
36 typedef int ExceptionCode; | 36 typedef int ExceptionCode; |
37 | 37 |
38 class NodeIterator : public ScriptWrappable, public RefCounted<NodeIterator>
, public Traversal { | 38 class NodeIterator : public ScriptWrappable, public RefCounted<NodeIterator>
, public Traversal { |
39 public: | 39 public: |
40 static PassRefPtr<NodeIterator> create(PassRefPtr<Node> rootNode, unsign
ed whatToShow, PassRefPtr<NodeFilter> filter, bool expandEntityReferences) | 40 static PassRefPtr<NodeIterator> create(PassRefPtr<Node> rootNode, unsign
ed whatToShow, PassRefPtr<NodeFilter> filter) |
41 { | 41 { |
42 return adoptRef(new NodeIterator(rootNode, whatToShow, filter, expan
dEntityReferences)); | 42 return adoptRef(new NodeIterator(rootNode, whatToShow, filter)); |
43 } | 43 } |
44 ~NodeIterator(); | 44 ~NodeIterator(); |
45 | 45 |
46 PassRefPtr<Node> nextNode(ScriptState*, ExceptionCode&); | 46 PassRefPtr<Node> nextNode(ScriptState*, ExceptionCode&); |
47 PassRefPtr<Node> previousNode(ScriptState*, ExceptionCode&); | 47 PassRefPtr<Node> previousNode(ScriptState*, ExceptionCode&); |
48 void detach(); | 48 void detach(); |
49 | 49 |
50 Node* referenceNode() const { return m_referenceNode.node.get(); } | 50 Node* referenceNode() const { return m_referenceNode.node.get(); } |
51 bool pointerBeforeReferenceNode() const { return m_referenceNode.isPoint
erBeforeNode; } | 51 bool pointerBeforeReferenceNode() const { return m_referenceNode.isPoint
erBeforeNode; } |
52 | 52 |
53 // This function is called before any node is removed from the document
tree. | 53 // This function is called before any node is removed from the document
tree. |
54 void nodeWillBeRemoved(Node*); | 54 void nodeWillBeRemoved(Node*); |
55 | 55 |
56 private: | 56 private: |
57 NodeIterator(PassRefPtr<Node>, unsigned whatToShow, PassRefPtr<NodeFilte
r>, bool expandEntityReferences); | 57 NodeIterator(PassRefPtr<Node>, unsigned whatToShow, PassRefPtr<NodeFilte
r>); |
58 | 58 |
59 struct NodePointer { | 59 struct NodePointer { |
60 RefPtr<Node> node; | 60 RefPtr<Node> node; |
61 bool isPointerBeforeNode; | 61 bool isPointerBeforeNode; |
62 NodePointer(); | 62 NodePointer(); |
63 NodePointer(PassRefPtr<Node>, bool); | 63 NodePointer(PassRefPtr<Node>, bool); |
64 void clear(); | 64 void clear(); |
65 bool moveToNext(Node* root); | 65 bool moveToNext(Node* root); |
66 bool moveToPrevious(Node* root); | 66 bool moveToPrevious(Node* root); |
67 }; | 67 }; |
68 | 68 |
69 void updateForNodeRemoval(Node* nodeToBeRemoved, NodePointer&) const; | 69 void updateForNodeRemoval(Node* nodeToBeRemoved, NodePointer&) const; |
70 | 70 |
71 NodePointer m_referenceNode; | 71 NodePointer m_referenceNode; |
72 NodePointer m_candidateNode; | 72 NodePointer m_candidateNode; |
73 bool m_detached; | 73 bool m_detached; |
74 }; | 74 }; |
75 | 75 |
76 } // namespace WebCore | 76 } // namespace WebCore |
77 | 77 |
78 #endif // NodeIterator_h | 78 #endif // NodeIterator_h |
OLD | NEW |