mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-24 17:09:43 +00:00 
			
		
		
		
	LibDevTools: Pull DOMNode type and related code into new Node.h
Accessibility nodes will share this code, so make it available, and rename DOMNode to Node.
This commit is contained in:
		
					parent
					
						
							
								eeb5446c1b
							
						
					
				
			
			
				commit
				
					
						d5fe7f7a98
					
				
			
		
		
		Notes:
		
			github-actions[bot]
		
		2025-10-20 09:52:37 +00:00 
		
	
	Author: https://github.com/AtkinsSJ
Commit: d5fe7f7a98
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/6462
Reviewed-by: https://github.com/trflynn89
	
					 5 changed files with 57 additions and 34 deletions
				
			
		|  | @ -11,20 +11,12 @@ | |||
| #include <AK/Traits.h> | ||||
| #include <LibDevTools/Actor.h> | ||||
| #include <LibDevTools/Forward.h> | ||||
| #include <LibDevTools/Node.h> | ||||
| #include <LibWeb/CSS/Selector.h> | ||||
| #include <LibWeb/Forward.h> | ||||
| 
 | ||||
| namespace DevTools { | ||||
| 
 | ||||
| struct DEVTOOLS_API NodeIdentifier { | ||||
|     static NodeIdentifier for_node(JsonObject const& node); | ||||
| 
 | ||||
|     bool operator==(NodeIdentifier const&) const = default; | ||||
| 
 | ||||
|     Web::UniqueNodeID id { 0 }; | ||||
|     Optional<Web::CSS::PseudoElement> pseudo_element; | ||||
| }; | ||||
| 
 | ||||
| class NodeActor final : public Actor { | ||||
| public: | ||||
|     static constexpr auto base_name = "node"sv; | ||||
|  |  | |||
|  | @ -388,19 +388,6 @@ JsonValue WalkerActor::serialize_root() const | |||
|     return serialize_node(m_dom_tree); | ||||
| } | ||||
| 
 | ||||
| static constexpr Web::DOM::NodeType parse_node_type(StringView type) | ||||
| { | ||||
|     if (type == "document"sv) | ||||
|         return Web::DOM::NodeType::DOCUMENT_NODE; | ||||
|     if (type == "element"sv) | ||||
|         return Web::DOM::NodeType::ELEMENT_NODE; | ||||
|     if (type == "text"sv) | ||||
|         return Web::DOM::NodeType::TEXT_NODE; | ||||
|     if (type == "comment"sv) | ||||
|         return Web::DOM::NodeType::COMMENT_NODE; | ||||
|     return Web::DOM::NodeType::INVALID; | ||||
| } | ||||
| 
 | ||||
| JsonValue WalkerActor::serialize_node(JsonObject const& node) const | ||||
| { | ||||
|     auto tab = m_tab.strong_ref(); | ||||
|  | @ -414,7 +401,7 @@ JsonValue WalkerActor::serialize_node(JsonObject const& node) const | |||
|     auto name = node.get_string("name"sv).release_value(); | ||||
|     auto type = node.get_string("type"sv).release_value(); | ||||
| 
 | ||||
|     auto dom_type = parse_node_type(type); | ||||
|     auto dom_type = parse_dom_node_type(type); | ||||
|     JsonValue node_value; | ||||
| 
 | ||||
|     auto is_top_level_document = &node == &m_dom_tree; | ||||
|  | @ -450,7 +437,7 @@ JsonValue WalkerActor::serialize_node(JsonObject const& node) const | |||
| 
 | ||||
|         if (auto parent_actor = m_dom_node_id_to_actor_map.get(parent_id); parent_actor.has_value()) { | ||||
|             if (auto parent_node = WalkerActor::dom_node_for(this, *parent_actor); parent_node.has_value()) { | ||||
|                 dom_type = parse_node_type(parent_node->node.get_string("type"sv).value()); | ||||
|                 dom_type = parse_dom_node_type(parent_node->node.get_string("type"sv).value()); | ||||
|                 is_displayed = !is_top_level_document && parent_node->node.get_bool("visible"sv).value_or(false); | ||||
|             } | ||||
|         } | ||||
|  | @ -518,14 +505,14 @@ JsonValue WalkerActor::serialize_node(JsonObject const& node) const | |||
|     return serialized; | ||||
| } | ||||
| 
 | ||||
| Optional<WalkerActor::DOMNode> WalkerActor::dom_node_for(WeakPtr<WalkerActor> const& weak_walker, StringView actor) | ||||
| Optional<Node> WalkerActor::dom_node_for(WeakPtr<WalkerActor> const& weak_walker, StringView actor) | ||||
| { | ||||
|     if (auto walker = weak_walker.strong_ref()) | ||||
|         return walker->dom_node(actor); | ||||
|     return {}; | ||||
| } | ||||
| 
 | ||||
| Optional<WalkerActor::DOMNode> WalkerActor::dom_node(StringView actor) | ||||
| Optional<Node> WalkerActor::dom_node(StringView actor) | ||||
| { | ||||
|     auto tab = m_tab.strong_ref(); | ||||
|     if (!tab) | ||||
|  | @ -538,7 +525,7 @@ Optional<WalkerActor::DOMNode> WalkerActor::dom_node(StringView actor) | |||
|     auto const& dom_node = *maybe_dom_node.value(); | ||||
|     auto identifier = NodeIdentifier::for_node(dom_node); | ||||
| 
 | ||||
|     return DOMNode { .node = dom_node, .identifier = move(identifier), .tab = tab.release_nonnull() }; | ||||
|     return Node { .node = dom_node, .identifier = move(identifier), .tab = tab.release_nonnull() }; | ||||
| } | ||||
| 
 | ||||
| Optional<JsonObject const&> WalkerActor::find_node_by_selector(JsonObject const& node, StringView selector) | ||||
|  |  | |||
|  | @ -13,6 +13,7 @@ | |||
| #include <LibDevTools/Actor.h> | ||||
| #include <LibDevTools/Actors/NodeActor.h> | ||||
| #include <LibDevTools/Forward.h> | ||||
| #include <LibDevTools/Node.h> | ||||
| #include <LibWeb/Forward.h> | ||||
| #include <LibWebView/Forward.h> | ||||
| 
 | ||||
|  | @ -28,13 +29,8 @@ public: | |||
|     static bool is_suitable_for_dom_inspection(JsonValue const&); | ||||
|     JsonValue serialize_root() const; | ||||
| 
 | ||||
|     struct DOMNode { | ||||
|         JsonObject const& node; | ||||
|         NodeIdentifier identifier; | ||||
|         NonnullRefPtr<TabActor> tab; | ||||
|     }; | ||||
|     static Optional<DOMNode> dom_node_for(WeakPtr<WalkerActor> const&, StringView actor); | ||||
|     Optional<DOMNode> dom_node(StringView actor); | ||||
|     static Optional<Node> dom_node_for(WeakPtr<WalkerActor> const&, StringView actor); | ||||
|     Optional<Node> dom_node(StringView actor); | ||||
| 
 | ||||
| private: | ||||
|     WalkerActor(DevToolsServer&, String name, WeakPtr<TabActor>, JsonObject dom_tree); | ||||
|  |  | |||
|  | @ -35,6 +35,7 @@ class WalkerActor; | |||
| class WatcherActor; | ||||
| 
 | ||||
| struct CSSProperty; | ||||
| struct Node; | ||||
| struct ProcessDescription; | ||||
| struct TabDescription; | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										47
									
								
								Libraries/LibDevTools/Node.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								Libraries/LibDevTools/Node.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,47 @@ | |||
| /*
 | ||||
|  * Copyright (c) 2025, Tim Flynn <trflynn89@ladybird.org> | ||||
|  * Copyright (c) 2025, Sam Atkins <sam@ladybird.org> | ||||
|  * | ||||
|  * SPDX-License-Identifier: BSD-2-Clause | ||||
|  */ | ||||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| #include <AK/JsonObject.h> | ||||
| #include <LibDevTools/Actors/TabActor.h> | ||||
| #include <LibDevTools/Forward.h> | ||||
| #include <LibWeb/CSS/PseudoElement.h> | ||||
| #include <LibWeb/DOM/NodeType.h> | ||||
| #include <LibWeb/Forward.h> | ||||
| 
 | ||||
| namespace DevTools { | ||||
| 
 | ||||
| struct DEVTOOLS_API NodeIdentifier { | ||||
|     static NodeIdentifier for_node(JsonObject const& node); | ||||
| 
 | ||||
|     bool operator==(NodeIdentifier const&) const = default; | ||||
| 
 | ||||
|     Web::UniqueNodeID id { 0 }; | ||||
|     Optional<Web::CSS::PseudoElement> pseudo_element; | ||||
| }; | ||||
| 
 | ||||
| struct DEVTOOLS_API Node { | ||||
|     JsonObject const& node; | ||||
|     NodeIdentifier identifier; | ||||
|     NonnullRefPtr<TabActor> tab; | ||||
| }; | ||||
| 
 | ||||
| static constexpr Web::DOM::NodeType parse_dom_node_type(StringView type) | ||||
| { | ||||
|     if (type == "document"sv) | ||||
|         return Web::DOM::NodeType::DOCUMENT_NODE; | ||||
|     if (type == "element"sv) | ||||
|         return Web::DOM::NodeType::ELEMENT_NODE; | ||||
|     if (type == "text"sv) | ||||
|         return Web::DOM::NodeType::TEXT_NODE; | ||||
|     if (type == "comment"sv) | ||||
|         return Web::DOM::NodeType::COMMENT_NODE; | ||||
|     return Web::DOM::NodeType::INVALID; | ||||
| } | ||||
| 
 | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue