| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Copyright (c) 2022, Andreas Kling <kling@serenityos.org> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * SPDX-License-Identifier: BSD-2-Clause | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <LibWeb/DOM/NodeFilter.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Web::DOM { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // https://dom.spec.whatwg.org/#treewalker
 | 
					
						
							| 
									
										
										
										
											2022-08-08 23:03:27 +02:00
										 |  |  | class TreeWalker final : public Bindings::PlatformObject { | 
					
						
							| 
									
										
										
										
											2022-11-29 20:45:09 +01:00
										 |  |  |     WEB_PLATFORM_OBJECT(TreeWalker, Bindings::PlatformObject); | 
					
						
							| 
									
										
										
										
											2022-08-08 23:03:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2022-08-08 23:03:27 +02:00
										 |  |  |     static JS::NonnullGCPtr<TreeWalker> create(Node& root, unsigned what_to_show, JS::GCPtr<NodeFilter>); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     virtual ~TreeWalker() override; | 
					
						
							| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-28 13:42:07 +02:00
										 |  |  |     JS::NonnullGCPtr<Node> current_node() const; | 
					
						
							| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  |     void set_current_node(Node&); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-28 13:42:07 +02:00
										 |  |  |     JS::ThrowCompletionOr<JS::GCPtr<Node>> parent_node(); | 
					
						
							|  |  |  |     JS::ThrowCompletionOr<JS::GCPtr<Node>> first_child(); | 
					
						
							|  |  |  |     JS::ThrowCompletionOr<JS::GCPtr<Node>> last_child(); | 
					
						
							|  |  |  |     JS::ThrowCompletionOr<JS::GCPtr<Node>> previous_sibling(); | 
					
						
							|  |  |  |     JS::ThrowCompletionOr<JS::GCPtr<Node>> next_sibling(); | 
					
						
							|  |  |  |     JS::ThrowCompletionOr<JS::GCPtr<Node>> previous_node(); | 
					
						
							|  |  |  |     JS::ThrowCompletionOr<JS::GCPtr<Node>> next_node(); | 
					
						
							| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-28 13:42:07 +02:00
										 |  |  |     JS::NonnullGCPtr<Node> root() { return m_root; } | 
					
						
							| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-08 23:03:27 +02:00
										 |  |  |     NodeFilter* filter() { return m_filter.ptr(); } | 
					
						
							| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     unsigned what_to_show() const { return m_what_to_show; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							| 
									
										
										
										
											2022-08-28 13:42:07 +02:00
										 |  |  |     explicit TreeWalker(Node& root); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-28 12:33:35 -05:00
										 |  |  |     virtual JS::ThrowCompletionOr<void> initialize(JS::Realm&) override; | 
					
						
							| 
									
										
										
										
											2022-08-08 23:03:27 +02:00
										 |  |  |     virtual void visit_edges(Cell::Visitor&) override; | 
					
						
							| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     enum class ChildTraversalType { | 
					
						
							|  |  |  |         First, | 
					
						
							|  |  |  |         Last, | 
					
						
							|  |  |  |     }; | 
					
						
							| 
									
										
										
										
											2022-08-28 13:42:07 +02:00
										 |  |  |     JS::ThrowCompletionOr<JS::GCPtr<Node>> traverse_children(ChildTraversalType); | 
					
						
							| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     enum class SiblingTraversalType { | 
					
						
							|  |  |  |         Next, | 
					
						
							|  |  |  |         Previous, | 
					
						
							|  |  |  |     }; | 
					
						
							| 
									
										
										
										
											2022-08-28 13:42:07 +02:00
										 |  |  |     JS::ThrowCompletionOr<JS::GCPtr<Node>> traverse_siblings(SiblingTraversalType); | 
					
						
							| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     JS::ThrowCompletionOr<NodeFilter::Result> filter(Node&); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // https://dom.spec.whatwg.org/#concept-traversal-root
 | 
					
						
							| 
									
										
										
										
											2022-08-28 13:42:07 +02:00
										 |  |  |     JS::NonnullGCPtr<Node> m_root; | 
					
						
							| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // https://dom.spec.whatwg.org/#treewalker-current
 | 
					
						
							| 
									
										
										
										
											2022-08-28 13:42:07 +02:00
										 |  |  |     JS::NonnullGCPtr<Node> m_current; | 
					
						
							| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // https://dom.spec.whatwg.org/#concept-traversal-whattoshow
 | 
					
						
							|  |  |  |     unsigned m_what_to_show { 0 }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // https://dom.spec.whatwg.org/#concept-traversal-filter
 | 
					
						
							| 
									
										
										
										
											2022-08-28 13:42:07 +02:00
										 |  |  |     JS::GCPtr<NodeFilter> m_filter; | 
					
						
							| 
									
										
										
										
											2022-03-09 14:37:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // https://dom.spec.whatwg.org/#concept-traversal-active
 | 
					
						
							|  |  |  |     bool m_active { false }; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |